修复ArrayList扩容机制的问题

对于奇数Old Capacity,右移操作:new Capacity = 1.5*Old Capacity - 0.5
This commit is contained in:
LIU 2020-11-18 13:57:39 +08:00 committed by GitHub
parent 36977963ca
commit bc230857ad
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -132,7 +132,7 @@ private static final int DEFAULT_CAPACITY = 10;
#### 2. 扩容 #### 2. 扩容
添加元素时使用 ensureCapacityInternal() 方法来保证容量足够如果不够时需要使用 grow() 方法进行扩容新容量的大小为 `oldCapacity + (oldCapacity \>\> 1)`也就是旧容量的 1.5 添加元素时使用 ensureCapacityInternal() 方法来保证容量足够如果不够时需要使用 grow() 方法进行扩容新容量的大小为 `oldCapacity + (oldCapacity >> 1)`也就是旧容量的 1.5 左右oldCapacity 为偶数就是 1.5 oldCapacity为奇数就是 1.5 -0.5奇偶不同比如 8+8/2 = 12, 13+13/2=19如果是奇数的话会丢掉小数
扩容操作需要调用 `Arrays.copyOf()` 把原数组整个复制到新数组中这个操作代价很高因此最好在创建 ArrayList 对象时就指定大概的容量大小减少扩容操作的次数 扩容操作需要调用 `Arrays.copyOf()` 把原数组整个复制到新数组中这个操作代价很高因此最好在创建 ArrayList 对象时就指定大概的容量大小减少扩容操作的次数