ArrayList扩容详解

ArrayList是Java中的动态数组,初始容量可变。无参数构造器创建时容量为0,带参数构造器按指定长度初始化。add()方法导致的扩容,首次扩容为10,之后按1.5倍增长。addAll()方法根据添加元素数量决定扩容,若超过10则按需扩容。已满时,扩容会选择更大容量以适应新增元素。
摘要由CSDN通过智能技术生成

ArrayList是实现了List集合的动态数组,其大小可以改变;

声明方式

ArrayList<> list=new ArrayList<>();
扩容机制

当调用无参构造函数时,集合初始长度为0;

当调用带参构造函数时,集合初始长度为指定长度

1、调用add()方法
  1. 第一次扩容长度为10 (0-9)

  1. 后续扩容为长度为前一次长度的1.5倍(扩容为创建一个新的数组,然后把旧数组的值拷贝到新数组中来代替旧数组,旧数组被回收)

2、调用addAll()方法

如果添加集合的数量长度小于10,则直接扩容为10;

如过添加集合的数量长度大于10,则扩容为添加集合的长度;

如果原本容量已满,则选择下次扩容的容量与想添加的数组间的较大值,进行扩容。

 例如:此时数组长度为10(满了),然后又要添加8个元素,这是扩容就应该是18,而不是15。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值