ArrayList自动扩容机制

ArrayList

ArrayList是List接口下的实现类,他的底层是数组,可以自动扩容;

无参构造ArrayList源代码底层数组如下:

当然也可以在创建ArrayList的时候指定数组的长度

ArrayList有三个构造方法

如果我们使用无参构造的方法的话,底层的数组默认长度就是10;

但是赋给底层数组的源代码显示数组的长度是0!!这是怎么会儿事??

原来

早期的jdk中,ArrayList的做法是直接创建一个初始容量为10的数组;

但是在jdk1.7与1.8之后,则是采用了空数组的做法;

此时会在第一次调用add()方法的时候,为初始数组进行扩容,在这时赋予了初始容量10

ArrayList在无参构造函数的时候,数组的默认长度并没有马上进行扩容,无参构造函数只是将ArrayList中的DEFAULTCAPACITY_EMPTY_ELEMENTDATA(一个空数组)赋值给了底层数组,所以当时数组的初始长度为0

ArrayList自动扩容是指当ArrayList中的元素个数超过了已分配的数组长度时,会自动对数组进行扩容。具体来说,当需要添加元素到ArrayList中时,如果当前元素个数已经达到了数组的长度,就会触发扩容操作。扩容操作会创建一个新的更大的数组,并将原数组中的元素复制到新数组中。通常情况下,ArrayList的扩容是以原来数组长度的1.5倍进行扩容的。这样做的目的是为了减少频繁的扩容操作,提高性能。\[1\]\[2\] #### 引用[.reference_title] - *1* [【Java集合】ArrayList自动扩容机制分析](https://blog.csdn.net/cy973071263/article/details/128690099)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [ArrayList自动扩容(详细篇)](https://blog.csdn.net/lz17267861157/article/details/131348110)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [ArrayList扩容机制](https://blog.csdn.net/TiankkTT/article/details/127221265)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值