ArrayList初始化容量的问题

ArrayList的初始化容量并非10,而是动态调整的。当创建ArrayList时,底层数组为空。首次添加元素时,容量会扩容到10。通过分析add()方法,涉及ensureCapacityInternal、calculateCapacity、ensureExplicitCapacity和grow()等方法,其中grow()方法按1.5倍扩容,确保至少能容纳新增元素。若超过最大数组容量,将抛出异常。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(所有的图片的代码来源于JDK1.8中的源码)

可能很多同学听到网上其他人说ArrayList的底层数组elementData的初始化容量是10。

其实并不是!,下图是我们经常初始化ArrayList使用的构造器:
这里写图片描述
而DEFAULTCAPACITY_EMPTY_ELEMENTDATA也是一个空的数组,请看下面的图示:
这里写图片描述

说白了就是,每次我们调用初始化一个空白的集合ArrayList,它的底层数组其实是空的。那人们说的初始化容量是10到底是从哪来的呢?

其实是:当我们第一次为ArrayList添加元素的时候,底层数组扩容到了10。

下面我们就分析一下这个过程:

当我们通过ArrayList调用add()方法添加元素的时候,其实底层一共需要调用了4个方法(如果需要扩容的话,则调用5个方法。Math.max()和Arrays.copyOf()不计入其内。)下面先给出源代

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值