一、列表和扩容机制

 JAVA的列表主要分为list和vector,list是线程不安全的。list又主要分为ArrayList和LinkedList,ArrayList底层通过object数组实现,可以实现快速查找,LinkedList底层通过双向列表实现。java常用的列表实现类为ArrayList,ArrayList的主要源码如下:

public class ArrayList<E> extends AbstractList<E>implements List<E>, RandomAccess, Cloneable, java.io.Serializable{}

再向ArrayList添加元素前,列表是一个空数组,占用的内存空间大小为0。

ensureCapacityInternal()

然后想列表继续添加第1、2、3、4......11元素时,列表判断到cap小于实际需求量时,又会继续执行扩容。扩容的机制是new_cap = cap+0.5cap,比如11的列表会扩容到15,当添加第16个元素时又会扩容到22,33等等

扩容的机制:

 private void grow(int minCapacity) {