虽然ArrayList是可变数组,但是为了提高性能我们在使用中应尽量提前估算容量,add()的时间复杂度为O(1),但是扩容会拉低性能,所以定义时应估算容量,减少扩容次数;remove()方法,每次删除要移动后边数组,所以时间复杂度为O(n),为提高性能,尽可能删除最后的数据。
一.Add()源码解析
数组扩容这是对ArrayList效率影响比较大的一个因素,虽然ArrayList可以自己扩容,但是扩容过程的空间复杂度应该是O(2n),因为需要拷贝一个次旧的数组。
现在看一下源码:
构造函数
new ArrayList()返回的是一个空的Object,所以新建的ArrayList初始容量为零。
new ArrayList(K)当K>0时,开辟K个空间;K=0,返回空的Object。
private static final int DEFAULT_CAPACITY = 10;
private static final Object[] EMPTY_ELEMENTDATA = {};
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
transient Object[] elementData;
private int size;
public ArrayList() {
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}
public ArrayList(int initi