private static final long serialVersionUID = 8683452581122892189L;//惟一序列号ID
private static final int DEFAULT_CAPACITY = 10;//jdk7以前初始容量为10,相似饿汉式,jdk8之后初始容量为0,相似懒汉式
private static final Object[] EMPTY_ELEMENTDATA = {};//有参构造且传入大小为0时的空数组
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};//无参构造的空数组
transient Object[] elementData; //实际存储元素的数组
private int size;//实际存储的元素个数
//构造函数
public ArrayList(int initialCapacity) {
if (initialCapacity > 0) {//懒汉式
this.elementData = new Object[initialCapacity];
} else if (initialCapacity == 0) {//饿汉式
this.elementData = EMPTY_ELEMENTDATA;
} else {//传入的初始容量小于0,非法,抛出异常
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
}
}
public ArrayList() {
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}
public ArrayList(Collection<? extends E> c) {
//传入一个集合,首先转换为Object数组。数组长度不为0时,若是传入的集合时ArrayList,那么直接赋值底层数组,不然复制底层数组。若是长度为0,那么相似有参构造方法参数为0的状况。
Object[] a = c.toArray();
if ((size = a.length) != 0) {
if (c.getClass() == ArrayList.class) {
elementData = a;
} else {
elementData = Arrays.copyOf(a, size, Object[].class);
}
} else {
// replace with empty array.
elementData = EMPTY_ELEMENTDATA;
}
}
public void trimToSize() {
//modCount是父抽象类AbstractList中的一个持久化变量,记录了ArrayList结构变化的次数。
modCount++;
//若是当前元素个数小于元素数组的长度时,元素数组会根据元素个数是否为0被修改位空数组或者当前数组size的copy。
if (size < elementData.length) {
elementData = (size == 0)
? EMPTY_ELEMENTDATA
: Arrays.copyOf(elementData, size);
}
}
public void ensureCapacity(int minCapacity) {
//若是要求的最小容量大于当前元素数组的长度,且元素数组非空或者要求的最小容量大于初始容量,那么就进行结构修改,使用增加,增加到最小容量。
if (minCapacity > elementData.length
&& !(elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA
&& minCapacity <= DEFAULT_CAPACITY)) {
modCount++;
grow(minCapacity);
}
}
private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;//最大元素数组容量为2^31-9。
private Object[] grow(int minCapacity) {
//增加的有参方法,将元素数组复制为一个新数组,长度为最小容量。
return elementData = Arrays.copyOf(elementData,
newCapacity(minCapacity));
}
private Object[] grow() {
//增加的无参构造方法,返回一个新数组,长度为当前元素个数+1。
return grow(size + 1);
}
private int newCapacity(int minCapacity) {
//newCapacity(min)是自动扩容方法。获取元素数组的长度为旧的容量,将新容量设置为旧容量的1.5倍,若是旧容量为0,那么替换为无参构造方法的空数组,若是扩容的长度溢出,那么抛出超出内存异常。自动扩容返回扩容后的长度。
//若是新容量是合法的,那么判断是否小于等于最大数组长度,若是是则返回新长度,不然返回调用hugeCapacity(min)方法的结果。
// overflow-conscious code
int oldCapacity = elementData.length;
int newCapacity = oldCapacity + (oldCapacity >> 1);
if (newCapacity - minCapacity <= 0) {
if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA)
return Math.max(DEFAULT_CAPACITY, minCapacity);
if (minCapacity < 0) // overflow
throw new OutOfMemoryError();
return minCapacity;
}
return (newCapacity - MAX_ARRAY_SIZE <= 0)
? newCapacity
: hugeCapacity(minCapacity);
}
private static int hugeCapacity(int minCapacity) {
//若是形参即原来长度就溢出的话,就抛出超出内存异常。不然判断原来的大小和最大数组内存的长度,返回2^31-1或2^31-9。
if (minCapacity < 0) // overflow
throw new OutOfMemoryError();
return (minCapacity > MAX_ARRAY_SIZE)
? Integer.MAX_VALUE
: MAX_ARRAY_SIZE;
}
public int size() {
//返回实际元素个数
return size;
}
public boolean isEmpty() {
//判断实际元素个数是否为0
return size == 0;
}
public boolean contains(Object o) {
//查找元素o在数组中第一次出现的下标,若是为-1就不存在。
return indexOf(o) >= 0;
}
public int indexOf(Object o) {
//调用indexOfRange(查找对象,0,实际元素个数)
return indexOfRange(o, 0, size);
}
int indexOfRange(Object o, int start, int end) {
//在存储元素的数组中查找,范围是[start,end)。若是查找null对象,使用==比较。若是查找非null对象,那么调用Object.equals()方法判断是否相等。找到则返回下标,找不到返回-1。
Object[] es = elementData;
if (o == null) {
for (int i = start; i < end; i++) {
if (es[i] == null) {
return i;
}
}
} else {
for (int i = start; i < end; i++) {
if (o.equals(es[i])) {
return i;
}
}
}
return -1;
}
public int lastIndexOf(Object o) {
//调用lastIndexOfRange()
return lastIndexOfRange(o, 0, size);
}
int lastIndexOfRange(Object o, int start, int end) {
//与indexOfRange()相似,可是是逆序查找。
Object[] es = elementData;
if (o == null) {
for (int i = end - 1; i >= start; i--) {
if (es[i] == null) {
return i;
}
}
} else {
for (int i = end - 1; i >= start; i--) {
if (o.equals(es[i])) {
return i;
}
}
}
return -1;
}
public Object clone() {
//调用父类的clone()方法,而且转换为(ArrayList<?>)类型,新对象的数组复制原来的数组,并将新对象的修改次数设置为0。若是克隆失败,抛出CloneNotSupportedException。E
try {
ArrayList<?> v = (ArrayList<?>) super.clone();
v.elementData = Arrays.copyOf(elementData, size);
v.modCount = 0;
return v;
} catch (CloneNotSupportedException e) {
// this shouldn't happen, since we are Cloneable
throw new InternalError(e);
}
}
public Object[] toArray() {
//返回元素数组的复制。
return Arrays.copyOf(elementData, size);
}
public <T> T[] toArray(T[] a) {
//泛型类型的数组复制。若是传入数组的长度小于实际元素个数,那么返回泛型数组类型的,列表中元素数组的复制。若是相等,直接复制,若是传入数组的长度大于实际元素个数,多余的位置用null填充。
if (a.length < size)
// Make a new array of a's runtime type, but my contents:
return (T[]) Arrays.copyOf(elementData, size, a.getClass());
System.arraycopy(elementData, 0, a, 0, size);
if (a.length > size)
a[size] = null;
return a;
}E elementData(int index) {//以泛型类型返回数组中指定位置的元素 return (E) elementData[index];
}
@SuppressWarnings("unchecked")
static <E> E elementAt(Object[] es, int index) {
//以泛型类型返回给定数组中指定位置的元素
return (E) es[index];
}
public E get(int index) {
//泛型方法get()首先调用Objects工具类中的checkIndex()方法,判断index是否在数组有效范围内。该方法其实是另外一个定义相同的方法的调用,若是不在范围内,抛出OutOfBoundsCheckIndex异常。不然返回下标对应的元素。
Objects.checkIndex(index, size);
return elementData(index);
}
public E set(int index, E element) {
//泛型方法set()首先判断是否越界。不越界就修改下标处元素的值,并返回原来下标处的值。
Objects.checkIndex(index, size);
E oldValue = elementData(index);
elementData[index] = element;
return oldValue;
}
private void add(E e, Object[] elementData, int s) {
//若是当前元素个数和长读相等,那么自动扩容一个长度。放入元素并使size++。
if (s == elementData.length)
elementData = grow();
elementData[s] = e;
size = s + 1;
}
public boolean add(E e) {
//修改次数+1,调用add()重载方法,返回true。
modCount++;
add(e, elementData, size);
return true;
}
public void add(int index, E element) {
//调用rangeCheckForAdd()
rangeCheckForAdd(index);
modCount++;
final int s;
Object[] elementData;
if ((s = size) == (elementData = this.elementData).length)
elementData = grow();
System.arraycopy(elementData, index,
elementData, index + 1,
s - index);
elementData[index] = element;
size = s + 1;
}
public E remove(int index) {
//首先判断index是否合法,若是合法,定义一个final数组等于当前元素数组,而后保留泛型元素,调用fastRemove(),并将泛型元素返回。
Objects.checkIndex(index, size);
final Object[] es = elementData;
@SuppressWarnings("unchecked") E oldValue = (E) es[index];
fastRemove(es, index);
return oldValue;
}
public boolean equals(Object o) {
//若是是同一个对象,返回true。若是不是List或其子类,返回false。若是是,判断对象的Clas是不是ArrayList,若是是就调用equalsArrayList()方法,不然调用equlsRange()方法
//最后调用checkForComodification()方法。
//在比较两个List的过程当中不能改变List的元素。不然会抛出并发修改异常。
if (o == this) {
return true;
}
if (!(o instanceof List)) {
return false;
}
final int expectedModCount = modCount;
// ArrayList can be subclassed and given arbitrary behavior, but we can
// still deal with the common case where o is ArrayList precisely
boolean equal = (o.getClass() == ArrayList.class)
? equalsArrayList((ArrayList<?>) o)
: equalsRange((List<?>) o, 0, size);
checkForComodification(expectedModCount);
return equal;
}
boolean equalsRange(List<?> other, int from, int to) {
//首先定义静态变量指向当前元素数组,若是范围上界大于数组长度,就抛出并发修改异常(ArrayList线程不一样步)。调用传入List的迭代器,判断每个元素是否相等,元素个数是否相等。一致返回true,不然返回false。
final Object[] es = elementData;
if (to > es.length) {
throw new ConcurrentModificationException();
}
var oit = other.iterator();
for (; from < to; from++) {
if (!oit.hasNext() || !Objects.equals(es[from], oit.next())) {
return false;
}
}
return !oit.hasNext();
}
private boolean equalsArrayList(ArrayList<?> other) {
//若是是两个ArrayList判断,先判断两个al的元素个数是否相等,若是相等,静态定义两个数组保存元素数组。若是当前元素个数超过数组长度,抛出并发修改异常。
//不然判断每一个元素是否相等。最后调用checkForComodification()方法。返回判断结果。
final int otherModCount = other.modCount;
final int s = size;
boolean equal;
if (equal = (s == other.size)) {
final Object[] otherEs = other.elementData;
final Object[] es = elementData;
if (s > es.length || s > otherEs.length) {
throw new ConcurrentModificationException();
}
for (int i = 0; i < s; i++) {
if (!Objects.equals(es[i], otherEs[i])) {
equal = false;
break;
}
}
}
other.checkForComodification(otherModCount);
return equal;
}
private void checkForComodification(final int expectedModCount) {
//判断列表的修改次数是否相等。(主要用于多线程时)
if (modCount != expectedModCount) {
throw new ConcurrentModificationException();
}
}
public int hashCode() {
//调用hashCodeRange()方法,再判断列表有没有修改,若是修改抛出并发修改异常。返回hash值。
int expectedModCount = modCount;
int hash = hashCodeRange(0, size);
checkForComodification(expectedModCount);
return hash;
}
int hashCodeRange(int from, int to) {
//若是元素个数大于数组长度,抛出并发修改异常。定义hash初值为1,遍历每一个数组元素,以31进制的方式返回hash和(数组元素为null时返回0)。返回hash和就是lisr的hash值。
final Object[] es = elementData;
if (to > es.length) {
throw new ConcurrentModificationException();
}
int hashCode = 1;
for (int i = from; i < to; i++) {
Object e = es[i];
hashCode = 31 * hashCode + (e == null ? 0 : e.hashCode());
}
return hashCode;
}
public boolean remove(Object o) {
//定义一个标记found,若是找到一个相等的元素就终止此次循环,但不从新进入循环。即找到第一个相等的元素,调用fastRemove(),并返回true。若是循环没有找到就返回false。
//注意若是o是整型,ArrayList会调用删除指定下标方法。由于它是适合更小范围的。
//迭代器遍历时不能调用remove方法,会引发并发修改异常。
final Object[] es = elementData;
final int size = this.size;
int i = 0;
found: {
if (o == null) {
for (; i < size; i++)
if (es[i] == null)
break found;
} else {
for (; i < size; i++)
if (o.equals(es[i]))
break found;
}
return false;
}
fastRemove(es, i);
return true;
}
private void fastRemove(Object[] es, int i) {
//修改次数++,若是不是删除最后一个元素,就复制后面的元素到前面。将最后一个元素赋值为null,将size-1。
modCount++;
final int newSize;
if ((newSize = size - 1) > i)
System.arraycopy(es, i + 1, es, i, newSize - i);
es[size = newSize] = null;
}
public void clear() {
//修改次数++,将元素数组全赋值为null,同时size赋值为0。
modCount++;
final Object[] es = elementData;
for (int to = size, i = size = 0; i < to; i++)
es[i] = null;
}
public boolean addAll(Collection<? extends E> c) {
//修改次数++,判断c转为数组的长度是否为0。若是为0直接返回false。若是数组剩余长度不足集合元素个数,扩容至恰好足够。将数组复制到元素数组汇总,修改size为当前个数,返回true。
Object[] a = c.toArray();
modCount++;
int numNew = a.length;
if (numNew == 0)
return false;
Object[] elementData;
final int s;
if (numNew > (elementData = this.elementData).length - (s = size))
elementData = grow(s + numNew);
System.arraycopy(a, 0, elementData, s, numNew);
size = s + numNew;
return true;
}
public boolean addAll(int index, Collection<? extends E> c) {
//调用rangeCheckForAdd(),修改次数++,与addAll()重载方法相似,是从index处插入。
rangeCheckForAdd(index);
Object[] a = c.toArray();
modCount++;
int numNew = a.length;
if (numNew == 0)
return false;
Object[] elementData;
final int s;
if (numNew > (elementData = this.elementData).length - (s = size))
elementData = grow(s + numNew);
int numMoved = s - index;
if (numMoved > 0)
System.arraycopy(elementData, index,
elementData, index + numNew,
numMoved);
System.arraycopy(a, 0, elementData, index, numNew);
size = s + numNew;
return true;
}
protected void removeRange(int fromIndex, int toIndex) {
//若是下界大于上界,抛出数组下标越界异常。不然修改次数++,调用shiftTrailOverGap()方法。
if (fromIndex > toIndex) {
throw new IndexOutOfBoundsException(
outOfBoundsMsg(fromIndex, toIndex));
}
modCount++;
shiftTailOverGap(elementData, fromIndex, toIndex);
}