vector与ArrayList扩容机制以及增长大小

在知乎上看到一个问题:vector为什么要用加倍扩容而不是每次增加一个固定的扩容容量?

我先了解了一下vector的扩容原理,vecctor底层是数组结构,是一段连续的数组,当集合也就是数组装满以后,如果还需要增加数据,为保证连续性,会重新申请更大的内存空间,然后将现有数据复制到新的内存空间中,再将新增数据添加到数组里面,释放原来的内存,其内存地址也相应改变,指向原vector的所有迭代器就都会失效。

为什么vector增长为原来的一倍,而arrayList增长为原来的一半?

ArrayList有两个属性,存储数据的数组elementData,和存储记录数目的size。
Vector有三个属性,存储数据的数组elementData,存储记录数目的elementCount,还有扩展数组大小的扩展因子 capacityIncrement。

对比两者结构,arrayList没有扩展因子,也就是说vector可以指定每次增长的容量,arrayList不可以指定扩展大小。

在知乎上找到了一篇很好的解释回答第一个问题:C++ STL中vector内存用尽后,为啥每次是两倍的增长,而不是3倍或其他数值? 

猜你喜欢

转载自blog.csdn.net/qq_wzs/article/details/84836434