用一道選擇題作為本文的開始吧!
ArrayList list = new ArrayList(20);中的list擴充幾次
A.0
B.1
C.2
D.3
答案:A
1、ArrayList的默認初始容量為10,當然也可以自定義指定初始容量,隨著動態的向其中添加元素,其容量可能會動態的增加,那么擴容的公式為:
新容量 = 舊容量/2 + 舊容量
比如:初始容量為4,其容量的每次擴充后的新容量為:4->6->9->13->19->…
即每次擴充至原有基礎的1.5倍
ArrayList的構造函數總共有三個:
(1)ArrayList()構造一個初始容量為 10 的空列表。
(2)ArrayList(Collection<? extends E> c)構造一個包含指定 collection 的元素的列表,這些元素是按照該 collection 的迭代器返回它們的順序排列的。
(3)ArrayList(int initialCapacity)構造一個具有指定初始容量的空列表。
調用的是第三個構造函數,直接初始化為大小為20的list,沒有擴容,所以選擇A
如果初始化為ArrayList(0),則會在新容量計算完畢后,增加至1;
另外與之類似的還有,
2、HashMap的初始大小為16,增長時,直接容量翻番,如源代碼。
1
2
3
4
5
6
7
8
|
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,如果沒有指定每次增長的大小,則默認是翻倍增長。
總結
以上就是本文關于ArrayList的自動擴充機制實例解析的全部內容,希望對大家有所幫助。有什么問題可以隨時留言,小編會及時回復大家的,感謝朋友們對本站的支持!
原文鏈接:http://blog.csdn.net/ysk_xh_521/article/details/77529198