ArrayList、HashMap等集合初始容量的大小以及扩容的倍数

比较

集合 默认初始化大小 扩容大小
ArrayList 10 1.5
Vector 10 2(默认)
HashMap 16 2(阈值0.75)
HashTable 11 2倍+1(阈值0.75)

ArrayList

无参构造器

由无参方法我们可以得到ArrayList如果不指定数组大小则它开始的大小为0,如果我们指定了初始大小,则elementData 的初始大小就变成了我们所指定的初始大小了

#无参构造方法
public ArrayList() {
   
 this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}

//默认的空数组常量
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMEN TDATA = {
   };

首次使用

默认容量大小为10

在插入元素之前,它会先检查是否需要扩容,然后再把元素添加到数组中最后一个元素的后面。在 ensureCapacityInternal 方法中,

我们可以看见,如果当 elementData 为空数组时,它会使用默认的大小去扩容。所以说,通过无参构造方法来创建 ArrayList 时,它的大小其实是为 0 的,只有在使用到的时候,才会通过 grow 方法去创建一个大小为 10 的数组。

private static final int DEFAULT_CAPACITY = 10;

扩容

grow 方法是在数组进行扩容的时候用到的,从中我们可以看见,ArrayList 每次扩容都是扩 1.5 倍,然后调用 Arrays 类的 copyOf 方法,把元素重新拷贝到一个新的数组中去。

private void grow(int minCapacity) {
   
 // overflow-conscious code
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Vivien_o.O

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值