欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java中Arraylist的最大長度

 更新時間:2022年02月28日 11:44:24   作者:隱者詭道  
這篇文章主要介紹了Java中Arraylist的最大長度,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Arraylist的最大長度

Arraylist的MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;

最近在學習java的基礎知識,學到集合的時候,在查看ArrayList的源碼的時候,發(fā)現(xiàn)了一個有趣的東西。

ArrayList集合的最大長度是多少?

/**
? ? ?* The maximum size of array to allocate.
? ? ?* Some VMs reserve some header words in an array.
? ? ?* Attempts to allocate larger arrays may result in
? ? ?* OutOfMemoryError: Requested array size exceeds VM limit
? ? ?*/
? ? private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;
? ? /**
? ? ?* Increases the capacity to ensure that it can hold at least the
? ? ?* number of elements specified by the minimum capacity argument.
? ? ?*
? ? ?* @param minCapacity the desired minimum capacity
? ? ?*/
? ? private void grow(int minCapacity) {
? ? ? ? // overflow-conscious code
? ? ? ? int oldCapacity = elementData.length;
? ? ? ? int newCapacity = oldCapacity + (oldCapacity >> 1);
? ? ? ? if (newCapacity - minCapacity < 0)
? ? ? ? ? ? newCapacity = minCapacity;
? ? ? ? if (newCapacity - MAX_ARRAY_SIZE > 0)
? ? ? ? ? ? newCapacity = hugeCapacity(minCapacity);
? ? ? ? // minCapacity is usually close to size, so this is a win:
? ? ? ? elementData = Arrays.copyOf(elementData, newCapacity);
? ? }
? ? private static int hugeCapacity(int minCapacity) {
? ? ? ? if (minCapacity < 0) // overflow
? ? ? ? ? ? throw new OutOfMemoryError();
? ? ? ? return (minCapacity > MAX_ARRAY_SIZE) ?
? ? ? ? ? ? Integer.MAX_VALUE :
? ? ? ? ? ? MAX_ARRAY_SIZE;
? ? }

源碼中定義MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;上面的注釋也寫明白了。

一些vm可能會在數(shù)組中保留一些header信息,分配更大的長度可能會導致OutOfMemoryError異常。

這里這樣做的原因是為了盡可能的避免因為vm使用了數(shù)據(jù)保存header的信息而導致分配更大的長度產(chǎn)生OutOfMemoryError異常。但是并不一定超出這個長度一定會異常。這只是為了盡可能的去避免。但是假使當一個vm使用了數(shù)組保存一些header,并且這些header使用的長度大于8時那么當數(shù)組擴容到2^31-1再減去header的信息長度時依舊會發(fā)生OutOfMemoryError異常。

Arraylist的最大長度為2147483647即2^31-1

arrayList的底層結構是基于數(shù)組實現(xiàn)的,作為下標的最大數(shù)據(jù)應該是Integer.MAX_VALUE即2^31-1。

我們觀察上面代碼中的grow(int minCapacity)會發(fā)現(xiàn)其中有一個特殊的地方

 ?if (newCapacity - MAX_ARRAY_SIZE > 0)
? ? ? ? ? ? newCapacity = hugeCapacity(minCapacity);

而hugeCapacity(int minCapacity)方法中表明了,

? ? private static int hugeCapacity(int minCapacity) {
? ? ? ? if (minCapacity < 0) // overflow
? ? ? ? ? ? throw new OutOfMemoryError();
? ? ? ? return (minCapacity > MAX_ARRAY_SIZE) ?
? ? ? ? ? ? Integer.MAX_VALUE :
? ? ? ? ? ? MAX_ARRAY_SIZE;
? ? }

新長度在滿足一定條件時是可以為Integer.MAX_VALUE的。

所以說Arraylist的最大長度為2147483647即2^31-1。 

ArrayList的擴容問題

ArrayList的容量有兩種

Sun公司的源代碼里面有以下兩種構造方法

1.無參的構造方法

無參的構造方法就是事先創(chuàng)建好一個空數(shù)組 當向該數(shù)組中添加第一個元素的時候 初始化容量為10

2.含參的構造方法

含參構造方法是傳入一個容量值 然后來進行定義容量的大小

接下來是關于容量滿了之后的擴容問題

擴容的原因是因為容量滿了 而能夠增加元素的方法是add() 所以擴容會和add()方法有關系

從下面的add()方法我們可以看出 該add()調(diào)用了另一個add()方法 我們點過去又會發(fā)現(xiàn) 擴容和grow()方法也有關系

這個是最后的擴容的grow()方法了 我們可以從中發(fā)現(xiàn)一個這個

最小容量增長值是minCapacity-oldCapacity 然后oldCapacity是位運算向右移一位

也就是增加的容量=原始容量-原始容量/2=0.5原始容量

所以擴容之后的容量是擴容之前的容量的1.5倍

另外 HashSet 底層是 HashMap 初始化容量16 擴容后*2 且初始化容量是2的倍數(shù) 擴容因子是0.75

Properties 初始化容量為11 擴容為 *2+1 擴容因子是0.75

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 經(jīng)典的Java面試題及回答集錦(基礎篇)

    經(jīng)典的Java面試題及回答集錦(基礎篇)

    本文給大家收藏整理了java面試題及回答,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2018-03-03
  • springboot項目獲取resources相對路徑的方法

    springboot項目獲取resources相對路徑的方法

    這篇文章主要介紹了springboot項目獲取resources相對路徑的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • Java JDK動態(tài)代理(AOP)用法及實現(xiàn)原理詳解

    Java JDK動態(tài)代理(AOP)用法及實現(xiàn)原理詳解

    在本篇文章了小編給大家整理的是一篇關于Java JDK動態(tài)代理(AOP)用法及實現(xiàn)原理詳解內(nèi)容,有需要的朋友們可以參考學習下。
    2020-10-10
  • Java JConsole遠程連接配置案例詳解

    Java JConsole遠程連接配置案例詳解

    這篇文章主要介紹了Java JConsole遠程連接配置案例詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • java異步寫日志到文件中實現(xiàn)代碼

    java異步寫日志到文件中實現(xiàn)代碼

    這篇文章主要介紹了java異步寫日志到文件中實現(xiàn)代碼的相關資料,需要的朋友可以參考下
    2017-04-04
  • Spring Boot整合Swagger2的完整步驟詳解

    Spring Boot整合Swagger2的完整步驟詳解

    這篇文章主要給大家介紹了關于Spring Boot整合Swagger2的完整步驟,文中通過示例代碼將整合的步驟一步步介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-07-07
  • Java比較器實現(xiàn)方法項目案例

    Java比較器實現(xiàn)方法項目案例

    這篇文章主要介紹了Java比較器實現(xiàn)方法,結合具體項目案例形式分析了Java比較器相關排序操作技巧,需要的朋友可以參考下
    2019-03-03
  • java實現(xiàn)學生信息錄入界面

    java實現(xiàn)學生信息錄入界面

    這篇文章主要為大家詳細介紹了java實現(xiàn)學生信息錄入界面,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 詳解Java中的阻塞隊列

    詳解Java中的阻塞隊列

    在去年的面試過程中,被面試官問道“阻塞隊列”這個問題,因為當時并沒有對此問題進行深入理解,只是按照自己的理解說明了該問題,最后面試結果也不太好,今天對該問題進行簡要的面試并記錄如下;如有錯誤,歡迎指正,需要的朋友可以參考下
    2021-06-06
  • Java三大特性之封裝詳解

    Java三大特性之封裝詳解

    面向對象編程語言是對客觀世界的模擬,客觀世界里成員變量都是隱藏在對象內(nèi)部的,外界無法直接操作和修改。?封裝可以被認為是一個保護屏障,防止該類的代碼和數(shù)據(jù)被其他類隨意訪問。本文將來和大家詳細說說Java中的封裝,需要的可以了解一下
    2022-10-10

最新評論