ArrayList是Java集合框架中的一个重要的类,它继承于AbstractList,实现了List接口,是一个长度可变的集合,提供了增删改查的功能。集合中允许null的存在。ArrayList类还是实现了RandomAccess接口,可以对元素进行快速访问。实现了Serializable接口,说明ArrayList可以被序列化,还有Cloneable接口,可以被复制。和Vector不同的是,ArrayList不是线程安全的。
    ArrayList重要的方法和属性
    ArrayList提供了三个构造函数:
    ArrayList():默认构造函数,提供初始容量为10的空列表。
    ArrayList(int initialCapacity):构造一个具有指定初始容量的空列表。
    ArrayList(Collection<? extends E> c):构造一个包含指定 collection 的元素的列表,这些元素是按照该 collection 的迭代器返回它们的顺序排列的。

    ArrayList内部封装了一个Object类型的数组,从一般的意义来说,它和数组没有本质的差别,甚至于ArrayList的许多方法,如Index、IndexOf、Contains、Sort等都是在内部数组的基础上直接调用Array的对应方法。
    数组扩容
    这是对ArrayList效率影响比较大的一个因素。
    每当执行Add、AddRange、Insert、InsertRange等添加元素的方法,都会检查内部数组的容量是否不够了,如果是,它就会以当前容量的两倍来重新构建一个数组,将旧元素Copy到新数组中,然后丢弃旧数组,在这个临界点的扩容操作,应该来说是比较影响效率的。

    LinkedList 是一个继承于AbstractSequentialList的双向链表。它也可以被当作堆栈、队列或双端队列进行操作。
    LinkedList 实现 List 接口,能对它进行队列操作。
    LinkedList 实现 Deque 接口,即能将LinkedList当作双端队列使用。
    LinkedList 实现了Cloneable接口,即覆盖了函数clone(),能克隆。
    LinkedList 实现java.io.Serializable接口,这意味着LinkedList支持序列化,能通过序列化去传输。
    LinkedList 是非同步的。

    LinkedList包含两个重要的成员:header 和 size。
    header是双向链表的表头,它是双向链表节点所对应的类Entry的实例。Entry中包含成员变量: previous, next, element。其中,previous是该节点的上一个节点,next是该节点的下一个节点,element是该节点所包含的值。
    size是双向链表中节点的个数。

    LinkedList实际上是通过双向链表去实现的。既然是双向链表,那么它的顺序访问会非常高效,而随机访问效率比较低。

    LinkedList是通过双向链表的,也实现了List接口{也就是说,它实现了get(int location)、remove(int location)等“根据索引值来获取、删除节点的函数”,是通过一个计数索引值来实现的。例如,当我们调用get(int location)时,首先会比较“location”和“双向链表长度的1/2”;若前者大,则从链表头开始往后查找,直到location位置;否则,从链表末尾开始先前查找,直到location位置。

    LinkedList 和 ArrayList 一样,都实现了 List 接口,但其内部的数据结构有本质的不同。LinkedList 是基于链表实现的(通过名字也能区分开来),所以它的插入和删除操作比 ArrayList 更加高效。但也是由于其为基于链表的,所以随机访问的效率要比 ArrayList 差。

    Vector 可实现自动增长的对象数组。
    Vector构造的时候
    1.如果不放入数字就是默认值10
    2.放入一个数的时候,就是默认的大小,当超过这个数的范围的时候,按照原容量的二倍扩增,重新分配内存
    3.放入两个数的时候,第一个是默认的大小,第二个数是一旦超过第一个数大的范围的时候,按照第二个扩增,重新分配内存

    提供了三种构造方法:
    public vector()
    public vector(int initialcapacity,int capacityIncrement)
    public vector(int initialcapacity)
    使用第一种方法系统会自动对向量进行管理,若使用后两种方法。则系统将根据参数,initialcapacity设定向量对象的容量(即向量对象可存储数据的大小),当真正存放的数据个数超过容量时。系统会扩充向量对象存储容量。
    参数capacityincrement给定了每次扩充的扩充值。当capacityincrement为0的时候,则没次扩充一倍,利用这个功能可以优化存储。在Vector类中提供了各种方法方便用户的使用:
    插入功能:
    (1)public final synchronized void adddElement(Object obj)
    将obj插入向量的尾部。obj可以是任何类型的对象。对同一个向量对象,亦可以在其中插入不同类的对象。但插入的应是对象而不是数值,所以插入数值时要注意将数组转换成相应的对象。
    例如:要插入整数1时,不要直接调用v1.addElement(1),正确的方法为:
    Vector v1 = new Vector();
    Integer integer1 = new Integer(1);
    v1.addElement(integer1);
    (2)public final synchronized void setElementAt(Object obj,int index)
    将index处的对象设置成obj,原来的对象将被覆盖。
    (3)public final synchronized void insertElement(Object obj,int index)
    在index指定的位置插入obj,原来对象以及此后的对象依次往后顺延。
    删除功能:
    (1)public final synchronized void removeElement(Object obj)
    从向量中删除obj,若有多个存在,则从向量头开始试,删除找到的第一个与obj相同的向量成员。
    (2)public final synchronized void removeAllElement();
    删除向量所有的对象
    (3)public fianl synchronized void removeElementAt(int index)
    删除index所指的地方的对象
    查询搜索功能:
    (1)public final int indexOf(Object obj)
    从向量头开始搜索obj,返回所遇到的第一个obj对应的下标,若不存在此obj,返回-1.
    (2)public final synchronized int indexOf(Object obj,int index)
    从index所表示的下标处开始搜索obj.
    (3)public final int lastindexOf(Object obj)
    从向量尾部开始逆向搜索obj.
    (4)public final synchornized int lastIndex(Object obj,int index)
    从index所表示的下标处由尾至头逆向搜索obj.
    (5)public final synchornized firstElement()
    获取向量对象中的首个obj
    (6)public final synchornized Object lastElement()
    获取向量对象的最后一个obj