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

Java中Arraylist的最大長度

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

Arraylist的最大長度

Arraylist的MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;

最近在學(xué)習(xí)java的基礎(chǔ)知識,學(xué)到集合的時候,在查看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信息,分配更大的長度可能會導(dǎo)致OutOfMemoryError異常。

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

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

arrayList的底層結(jié)構(gòu)是基于數(shù)組實(shí)現(xiàn)的,作為下標(biāo)的最大數(shù)據(jù)應(yīng)該是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的擴(kuò)容問題

ArrayList的容量有兩種

Sun公司的源代碼里面有以下兩種構(gòu)造方法

1.無參的構(gòu)造方法

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

2.含參的構(gòu)造方法

含參構(gòu)造方法是傳入一個容量值 然后來進(jìn)行定義容量的大小

接下來是關(guān)于容量滿了之后的擴(kuò)容問題

擴(kuò)容的原因是因?yàn)槿萘繚M了 而能夠增加元素的方法是add() 所以擴(kuò)容會和add()方法有關(guān)系

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

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

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

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

所以擴(kuò)容之后的容量是擴(kuò)容之前的容量的1.5倍

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

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

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

相關(guān)文章

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

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

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

    springboot項(xiàng)目獲取resources相對路徑的方法

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

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

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

    Java JConsole遠(yuǎn)程連接配置案例詳解

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

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

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

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

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

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

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

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

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

    詳解Java中的阻塞隊(duì)列

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

    Java三大特性之封裝詳解

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

最新評論