亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

ArrayList集合初始化及擴容方式

 更新時間:2023年03月13日 10:32:02   作者:小心!!  
這篇文章主要介紹了關(guān)于ArrayList集合初始化及擴容方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

ArrayList集合初始化及擴容

ArrayList 集合

1.默認初始化容量為10(底層先創(chuàng)建了一個長度為0的數(shù)組,當添加第一個元素的時候,初始化容量為10)

2.集合底層為一個Object[]數(shù)組

3.構(gòu)造方法:

new ArrayList();
new ArrayList(20);

4.ArrayList集合的擴容:原容量的1.5倍。

ArrayList集合的底層是數(shù)組,怎么優(yōu)化?

盡可能的減少擴容。因為數(shù)組擴容效率比較低,建議在使用Arraylist集合的時候預估計元素的個數(shù),給定一個初始化容量。

5.數(shù)組優(yōu)點:檢索效率比較高

6.數(shù)組缺點:隨機增刪元素效率比較低

7.向數(shù)組末尾添加元素,效率很高,不受影響

8.面試官經(jīng)常問的一個問題:

這么多集合中,你用那個集合最多?

答:ArrayList集合

因為往數(shù)組末尾添加元素,對效率不受影響。

另外,我們檢索查找某個元素的操作比較多。

package Collection;

import java.util.ArrayList;
import java.util.List;

/*
ArrayList 集合:
1.默認初始化容量為10(底層先創(chuàng)建了一個長度為0的數(shù)組,當添加第一個元素的時候,初始化容量為10)
2.集合底層為一個Object[]數(shù)組
3.構(gòu)造方法:
     new ArrayList();
     new ArrayList(20);
4.ArrayList集合的擴容:
    原容量的1.5倍。
    ArrayList集合的底層是數(shù)組,怎么優(yōu)化?
      盡可能的減少擴容。因為數(shù)組擴容效率比較低,建議在使用Arraylist集合的
     時候預估計元素的個數(shù),給定一個初始化容量。
5.數(shù)組優(yōu)點:
     檢索效率比較高
6.數(shù)組缺點:
     隨機增刪元素效率比較低
7.向數(shù)組末尾添加元素,效率很高,不受影響
8.面試官經(jīng)常問的一個問題:
  這么多集合中,你用那個集合最多?
    答:ArrayList集合
    因為往數(shù)組末尾添加元素,對效率不受影響。
    另外,我們檢索查找某個元素的操作比較多。
 */
public class ArrayLisTest01 {
    public static void main(String[] args) {
        List l1=new ArrayList();
        //集合的size方法是獲取當前集合元素的個數(shù),不是獲取集合的容量
        System.out.println(l1.size());

        List l2=new ArrayList(20);
        System.out.println(l2.size());

    }
}

ArrayList擴容機制(原理)

ArrayList擴容的本質(zhì)就是計算出新的擴容數(shù)組的size后實例化,并將原有數(shù)組內(nèi)容復制到新數(shù)組中去。(不是原數(shù)組,而是新數(shù)組然后給予數(shù)組對象地址)。

默認情況下,新的容量會是原容量的1.5倍。 新容量=舊容量右移一位(相當于除于2)在加上舊容量

ArrayList 的底層是用動態(tài)數(shù)組來實現(xiàn)的。我們初始化一個ArrayList 集合還沒有添加元素時,其實它是個空數(shù)組,只有當我們添加第一個元素時,內(nèi)部會調(diào)用擴容方法并返回最小容量10,也就是說ArrayList 初始化容量為10。

當前數(shù)組長度小于最小容量的長度時(前期容量是10,當添加第11個元素時就就擴容),便開始可以擴容了,ArrayList 擴容的真正計算是在一個grow()里面,新數(shù)組大小是舊數(shù)組的1.5倍,如果擴容后的新數(shù)組大小還是小于最小容量,那新數(shù)組的大小就是最小容量的大小,后面會調(diào)用一個Arrays.copyof方法,這個方法是真正實現(xiàn)擴容的步驟。

總結(jié)

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

相關(guān)文章

  • Java8中的Stream?流實踐操作

    Java8中的Stream?流實踐操作

    這篇文章主要介紹了Java8中的Stream?流實踐操作,Stream?是?java8?中處理集合的抽象概念,可以執(zhí)行非常復雜的查詢、過濾和映射數(shù)據(jù)等操作,下文更多相關(guān)資料介紹,需要的朋友可以參考一下
    2022-05-05
  • Java接口的作用_動力節(jié)點Java學院整理

    Java接口的作用_動力節(jié)點Java學院整理

    這篇文章主要介紹了Java接口的作用,涉及到接口的規(guī)范相關(guān)知識,需要的的朋友參考下
    2017-04-04
  • Java GC垃圾回收算法分析

    Java GC垃圾回收算法分析

    垃圾回收機制簡稱GC,主要用于Java堆的管理。在JVM中程序計數(shù)器、虛擬機棧、本地方法棧生命周期隨跟隨線程,棧幀的進棧和入棧能實現(xiàn)自動清理。而 jdk8后元空間為本地內(nèi)存也不受GC控制,所以垃圾回收主要是在堆中
    2022-12-12
  • 教你如何使用JAVA POI

    教你如何使用JAVA POI

    今天教大家怎么學習JAVA POI的用法,文中有非常詳細的代碼示例,對正在學習java的小伙伴們有很好地幫助,需要的朋友可以參考下
    2021-05-05
  • JNDI,JTA和JMS簡介

    JNDI,JTA和JMS簡介

    這篇文章主要介紹了JNDI,JTA和JMS的相關(guān)內(nèi)容,包括中文釋義,概念解釋等,需要的朋友可以了解下。
    2017-09-09
  • springcloud+nacos實現(xiàn)灰度發(fā)布示例詳解

    springcloud+nacos實現(xiàn)灰度發(fā)布示例詳解

    這篇文章主要介紹了springcloud+nacos實現(xiàn)灰度發(fā)布,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • TF-IDF理解及其Java實現(xiàn)代碼實例

    TF-IDF理解及其Java實現(xiàn)代碼實例

    這篇文章主要介紹了TF-IDF理解及其Java實現(xiàn)代碼實例,簡單介紹了tfidf算法及其相應(yīng)公式,然后分享了Java實現(xiàn)代碼,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • javaWeb實現(xiàn)學生信息管理系統(tǒng)

    javaWeb實現(xiàn)學生信息管理系統(tǒng)

    這篇文章主要為大家詳細介紹了javaWeb實現(xiàn)學生信息管理系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • Java面向?qū)ο筮x擇題總結(jié)歸納

    Java面向?qū)ο筮x擇題總結(jié)歸納

    今天小編就為大家分享一篇關(guān)于Java面向?qū)ο筮x擇題總結(jié)歸納,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • java正則表達式獲取url的host示例

    java正則表達式獲取url的host示例

    使用httpclient抓取頁面信息時需要填寫HOST,使用此正則提取抓取URL的HOST內(nèi)容
    2014-02-02

最新評論