久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

        手機站
        千鋒教育

        千鋒學習站 | 隨時隨地免費學

        千鋒教育

        掃一掃進入千鋒手機站

        領取全套視頻
        千鋒教育

        關注千鋒學習站小程序
        隨時隨地免費學習課程

        當前位置:首頁  >  技術干貨  > java中ArrayList集合的擴容機制

        java中ArrayList集合的擴容機制

        來源:千鋒教育
        發(fā)布人:qyf
        時間: 2022-08-09 15:34:00 1660030440

        java中ArrayList集合的擴容機制

          1、擴容要看添加方法,從屬性中可以看出有一個DEFAULT_CAPACITY屬性值10。

          public boolean add(E e) {

          // 驗證是否需要擴容操作

          ensureCapacityInternal(size + 1); // Increments modCount!!

          // 在對應的下標下添加值

          elementData[size++] = e;

          return true;

          }

          2、剛剛進入ensureCapacityInternal(size+1)size是一個完整的變量。

          標記了ArrayList的大小(包含的元素數(shù)),而此時沒有元素的是ensureCapacityInternal(0+1)。

          //1、進入這個方法

          private void ensureCapacityInternal(int minCapacity) {

          //2、先調用calculateCapacity(elementData, minCapacity)、這個方法就是檢查第一次添加數(shù)據(jù)、并返回默認的容器大小(就是10)

          // 4、就是執(zhí)行這個方法ensureExplicitCapacity(10) // 為什么參數(shù)是10、就是因為這個方法calculateCapacity(elementData, minCapacity)做了操作。

          ensureExplicitCapacity(calculateCapacity(elementData, minCapacity));

          }

          //3、數(shù)組容量計算

          private static int calculateCapacity(Object[] elementData, int minCapacity) {

          // 這個能處理就是第一次添加數(shù)據(jù)時為真

          if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {

          // 然后這個成立、這個方法是取參數(shù)1和參數(shù)2、兩個數(shù)之間的值

          // DEFAULT_CAPACITY : 默認為10

          // minCapacity : 第一次添加數(shù)據(jù)為1

          // 所以10 和 1 、10大、最后將10返回出去

          return Math.max(DEFAULT_CAPACITY, minCapacity);

          }

          return minCapacity;

          }

          //5、確保顯式容量

          private void ensureExplicitCapacity(int minCapacity) {

          modCount++;

          // 6、做判斷、

          // 第一次添加數(shù)據(jù)時 為 10-0 > 0 :第一次可以成立

          // 第二次添加數(shù)據(jù)時 為 2-10 > 0 :第二次可以不成立

          if (minCapacity - elementData.length > 0)

          //7、執(zhí)行下面方法、這個方法的作用才是正真的實施擴容并確定首次擴容ArrayList容器大小的方法

          grow(minCapacity);//擴容

          }

          以上就是java中ArrayList集合的擴容機制,希望對大家有所幫助。更多關于“Java培訓”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓經(jīng)驗,課程大綱更科學更專業(yè),有針對零基礎的就業(yè)班,有針對想提升技術的好程序員班,高品質課程助力你實現(xiàn)java程序員夢想。

        tags:
        聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
        10年以上業(yè)內強師集結,手把手帶你蛻變精英
        請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
        免費領取
        今日已有369人領取成功
        劉同學 138****2860 剛剛成功領取
        王同學 131****2015 剛剛成功領取
        張同學 133****4652 剛剛成功領取
        李同學 135****8607 剛剛成功領取
        楊同學 132****5667 剛剛成功領取
        岳同學 134****6652 剛剛成功領取
        梁同學 157****2950 剛剛成功領取
        劉同學 189****1015 剛剛成功領取
        張同學 155****4678 剛剛成功領取
        鄒同學 139****2907 剛剛成功領取
        董同學 138****2867 剛剛成功領取
        周同學 136****3602 剛剛成功領取
        相關推薦HOT
        咸宁市| 望都县| 若尔盖县| 金昌市| 黑山县| 屯昌县| 湾仔区| 章丘市| 惠安县| 夏河县| 广元市| 昭觉县| 泸水县| 绥阳县| 大理市| 夏津县| 宿州市| 行唐县| 车致| 新巴尔虎左旗| 景泰县| 锡林郭勒盟| 荔浦县| 突泉县| 南部县| 宜宾市| 武隆县| 图们市| 墨玉县| 宜宾县| 娱乐| 旺苍县| 勐海县| 博爱县| 南漳县| 凤凰县| 彰化县| 峨边| 浦东新区| 张家港市| 奉节县|