这三者都可以随机访问,也就是支持通过索引查找数据。 都是有序(可以实现元素怎么进怎么出)

Vector和ArrayList比较

相同之处

1 它们都是List

它们都继承于AbstractList,并且实现List接口。

3 它们都是通过数组实现的,本质上都是动态数组

4 它们的默认数组容量是10

不同之处

1 线程安全性不一样

ArrayList是非线程安全;
   而Vector是线程安全的,它的函数都是synchronized的,即都是支持同步的。
   ArrayList适用于单线程,Vector适用于多线程。

2 对序列化支持不同

ArrayList支持序列化,而Vector不支持;即ArrayList有实现java.io.Serializable接口,而Vector没有实现该接口。

3 虽然默认容量都是10,但是Vector在构造函数中就初始化数组了,ArrayList是在add方法中,第一次添加元素时才初始化数组。

4 容量增加方式不同

逐个添加元素时,若ArrayList容量不足时,“新的容量”=“原始容量x3/2 ”。
   而Vector的容量增长与“增长系数有关”,若指定了“增长系数”,且“增长系数有效(即,大于0)”;那么,每次容量不足时,“新的容量”=“原始容量+增长系数”。若增长系数无效(即,小于/等于0),则“新的容量”=“原始容量 x 2”。

ArrayList和LinkedList比较

相同:

1.它们都是List,可以通过索引访问。

2.有序(可以实现怎么进怎么出)

不同:

1.底层实现不同:ArrayList是数组,LinkedList是双向链表

2.ArrayList要扩容,linkedlist不用

05-11 19:30