这个容器类似于ArrayList,但是是一个线程安全的容器。
不同点:
1、有一个capacityIncrement,自动扩容时需要,若小于等于0,则扩容时每次都是容量的两倍。
private void grow(int minCapacity) {
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + ((capacityIncrement > 0) ?
capacityIncrement : oldCapacity);
if (newCapacity - minCapacity < 0)
newCapacity = minCapacity;
if (newCapacity - MAX_ARRAY_SIZE > 0)
newCapacity = hugeCapacity(minCapacity);
elementData = Arrays.copyOf(elementData, newCapacity);
}
ArrayList的扩容时每次都是两倍,没有判断,其余扩容步骤相同。
2、
相同:
1、初始默认容量为10.
博客介绍了Vector容器,它类似于ArrayList,是线程安全的。对比了两者不同点,Vector有capacityIncrement,扩容时若其小于等于0则容量变为两倍,而ArrayList扩容直接两倍;相同点是初始默认容量都为10。
12万+

被折叠的 条评论
为什么被折叠?



