ArrayList的自動(dòng)擴(kuò)充機(jī)制實(shí)例解析
用一道選擇題作為本文的開始吧!
ArrayList list = new ArrayList(20);中的list擴(kuò)充幾次
A.0
B.1
C.2
D.3
答案:A
1、ArrayList的默認(rèn)初始容量為10,當(dāng)然也可以自定義指定初始容量,隨著動(dòng)態(tài)的向其中添加元素,其容量可能會(huì)動(dòng)態(tài)的增加,那么擴(kuò)容的公式為:
新容量 = 舊容量/2 + 舊容量
比如:初始容量為4,其容量的每次擴(kuò)充后的新容量為:4->6->9->13->19->…
即每次擴(kuò)充至原有基礎(chǔ)的1.5倍
ArrayList的構(gòu)造函數(shù)總共有三個(gè):
(1)ArrayList()構(gòu)造一個(gè)初始容量為 10 的空列表。
(2)ArrayList(Collection<? extends E> c)構(gòu)造一個(gè)包含指定 collection 的元素的列表,這些元素是按照該 collection 的迭代器返回它們的順序排列的。
(3)ArrayList(int initialCapacity)構(gòu)造一個(gè)具有指定初始容量的空列表。
調(diào)用的是第三個(gè)構(gòu)造函數(shù),直接初始化為大小為20的list,沒有擴(kuò)容,所以選擇A
如果初始化為ArrayList(0),則會(huì)在新容量計(jì)算完畢后,增加至1;
另外與之類似的還有,
2、HashMap的初始大小為16,增長(zhǎng)時(shí),直接容量翻番,如源代碼。
void addEntry(int hash, K key, V value, int bucketIndex) {
if ((size >= threshold) && (null != table[bucketIndex])) {
resize(2 * table.length);//原容量2倍
hash = (null != key) ? hash(key) : 0;
bucketIndex = indexFor(hash, table.length);
}
createEntry(hash, key, value, bucketIndex);
}
3、Vector的初始大小為10,如果沒有指定每次增長(zhǎng)的大小,則默認(rèn)是翻倍增長(zhǎng)。
總結(jié)
以上就是本文關(guān)于ArrayList的自動(dòng)擴(kuò)充機(jī)制實(shí)例解析的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:Spring Java-based容器配置詳解、ArrayList在for循環(huán)中使用remove方法移除元素方法介紹等,有什么問題可以隨時(shí)留言,小編會(huì)及時(shí)回復(fù)大家的,感謝朋友們對(duì)本站的支持!
相關(guān)文章
Mockito mock Kotlin Object類方法報(bào)錯(cuò)解決方法
這篇文章主要介紹了Mockito mock Kotlin Object類方法報(bào)錯(cuò)解決方法,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
Spring前后端跨域請(qǐng)求設(shè)置代碼實(shí)例
這篇文章主要介紹了Spring前后端跨域請(qǐng)求設(shè)置代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
java實(shí)現(xiàn)圖片滑動(dòng)驗(yàn)證(包含前端代碼)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)圖片滑動(dòng)驗(yàn)證,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12
SpringMVC將請(qǐng)求和響應(yīng)的數(shù)據(jù)轉(zhuǎn)換為JSON格式的幾種方式
這篇文章主要給大家介紹餓了SpringMVC將請(qǐng)求和響應(yīng)的數(shù)據(jù)轉(zhuǎn)換為JSON格式的幾種方式,文中通過代碼示例和圖文結(jié)合給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2023-11-11
springboot項(xiàng)目中PropertySource如何讀取yaml配置文件
這篇文章主要介紹了springboot項(xiàng)目中PropertySource如何讀取yaml配置文件問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01

