Java集合 ArrayList 扩容

本文探讨了Java集合框架中的ArrayList,详细解析了ArrayList的源码,特别是其扩容机制。首次创建时,默认容量为0,首次添加元素时会扩容至10。之后每次扩容按1.5倍进行。此外,还概述了Java集合的分类,包括List、Set及Map的子类,如HashSet、TreeSet、HashMap等,并展示了对应的类图。
摘要由CSDN通过智能技术生成

Java的集合框架

集合的分类

可以分为单列集合和双列集合

单列集合主要有Collection下面的List与Set,其中List最长被用到的是ArrayList与LinkedList以及Vctor三种 Set最常用的是我们的HashSet以及TreeSet linkedHashSet可以使Set有序(插入与输出)

Collection都可以使用迭代器进行迭代

UML 类图如下
在这里插入图片描述
在这里插入图片描述

双列集合Map是基类

Map集合下常用的有HashMap与ConcurrentHashMap 、TreeMap、以及LinkedHashMap(保证插入的顺序与输出的顺序一致)

类图如下

ArrayList的源码解析

1、无参构造方法第一次构建创建的数组使{} 没有值 长度是0
在这里插入图片描述

list第一次添加元素,不管什么时候添加元素都会查看是需要进行扩容
在这里插入图片描述

计算所需要的容量第一次默认是数组大小是10
在这里插入图片描述
在这里插入图片描述grow()是进行扩容的方法除了第一次默认是10 以后每一次都是扩容1.5倍
在这里插入图片描述

如果使用有参构造方法的话每次以后每次扩容1.5倍 不演示调试截图了

  • 代码整理
// 存储数据的集合
transient Object[] elementData; // non-private to simplify nested class access  
private 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值