ArrayList底层结构和源码分析
ArrayList的注意事项
- permits all elements, including null ,ArrayList可以加入null,并且多个
- ArrayList是由数组来实现数据存储的
- ArrayList基本等同于Vector,除了ArrayList是线程不安全(执行效率高)看源码,在多线程情况下,不建议使用ArrayList
import java.util.ArrayList;
public class ArrayListDetail {
public static void main(String[] args) {
//ArrayList 是线程不安全的,可以看源码,没有synchronized
ArrayList arrayList = new ArrayList();
arrayList.add(null);
arrayList.add(null);
arrayList.add("jack");
System.out.println(arrayList);
}
}
ArrayList的底层操作机制源码分析(重点,难点)
- ArrayList中维护了一个Object类型的数组elementData. transient Object[] elementData;//transient:表示瞬间,短暂的,表示该属性不会被序列化
- 当创建ArrayList对象时,如果使用的是无参构造器,则初始elementData容量为0,第1次添加,则扩容elementData为10,如需要再次扩容,则扩容elementData为1.5倍。
- 如果使用的是指定大小的构造器,则初始elementData容量为指定大小,如果需要扩容,则直接扩容elementData为1.5倍。