程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 更多編程語言 >> 編程解疑 >> arraylist-ArrayList底層的動態數組怎麼實現?

arraylist-ArrayList底層的動態數組怎麼實現?

編輯:編程解疑
ArrayList底層的動態數組怎麼實現?

數組怎麼實現動態分配長度?數組的長度為什麼不固定?求大神講解

最佳回答:


沒有動態,最終還是數組復制,小數組換大數組

//這是數據擴充的核心代碼,最終就是arrays.copyof
 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);
     }
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved