前言
人生路很长,我们每个人的每一步都走的非常迷茫。但是,即使这样,我们依然要脚踏实地的向前走。今天,学习ArrayList组件中的属性及构造方法,小结一下。
为什么使用集合
当我们需要保存一组类型相同的数据的时候,我们应该是用一个容器来保存,这个容器就是数组,但是,使用数组存储对象具有一定的弊端, 因为我们在实际开发中,存储的数据的类型是多种多样的,于是,就出现了“集合”,集合同样也是用来存储多个数据的。
数组的缺点是一旦声明之后,长度就不可变了;同时,声明数组时的数据类型也决定了该数组存储的数据的类型;而且,数组存储的数据是有序的、可重复的,特点单一。 但是集合提高了数据存储的灵活性,Java 集合不仅可以用来存储不同类型不同数量的对象,还可以保存具有映射关系的数据。
今天,主要学习了变量以及常用的构造方法,话不多说,上代码。
属性
//默认的初始容量,且默认初始容量为10。
private static final int DEFAULT_CAPACITY = 10;
//用于空实例共享空数组实例。
private static final Object[] EMPTY_ELEMENTDATA = {};
//作用是将其与空元素的数据区分开,以知道何时去添加第一个元素。
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
//存储ArrayList元素的数组缓冲区。
//ArrayList的容量是这个数组缓冲区的长度。任何
//elementData==DEFAULTCAPACITY_empty_elementData的空ArrayList
//当添加第一个元素时,将扩展到默认的容量。
//注意!这里使用transient,
//transient作用是阻止被修饰的变量的值被序列化。
transient Object[] elementData;
//arrayList包含的元素数量。
private int size;
构造方法
public ArrayList(int initialCapacity) {
//如果大于0是那么就将用户给的容量设置为数据缓冲数组的长度。
if (initialCapacity > 0) {
this.elementData = new Object[initialCapacity];
} else if (initialCapacity == 0) {
//如果初始容量为零,那么数据缓冲区就是一个空的数组。
this.elementData = EMPTY_ELEMENTDATA;
} else {
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
}
}
//当创建一个空的集合时,就有了默认容量,即为10。
public ArrayList() {
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}
//构造一个包含指定集合元素的列表,该列表按集合的迭代器返回的顺序排列。
public ArrayList(Collection<? extends E> c) {
//此构造方法是传递进来一个,然后传递进来之后,会将集合转换为数组
//转换的过程是通过Arrays.copyof()方法复制了一个新的数组然后给到
//当前当前数组。
elementData = c.toArray();
//如果存储数据的数组的长度等于集合的长度且不等于0
if ((size = elementData.length) != 0) {
//这里有一个bug是因为向下转型导致,因为当父类引用指向子类对象时
//调用方法时默认调用的是子类中的方法,所以有可能返回的对象不与实际返回对象一致。
if (elementData.getClass() != Object[].class)
//如果返回的对象不是Object.class
//就在复制一个数组,我理解的就是将类型转换,然后初始化当前数组。
elementData = Arrays.copyOf(elementData, size, Object[].class);
} else {
//如果等于0则默认为空数组。
this.elementData = EMPTY_ELEMENTDATA;
}
}
未完待续…