首先 这三者都实现了java集合框架List 所谓的有序集合,因此具体功能比较相似,比如提供定位,添加,删除的操作。都提供迭代器遍历,但是因为具体的设计区别在行为,性能,线程安全等方向又有很大的不同。
- Vector 是java早期提供线程安全的动态数组,如果不需要线程安全,不建议选择。同步有额外的开销,Vectory内部使用对象数组来保存数据的,可以根据需要自动增加容量,当数组已满会创建新的数组,并拷贝原数组。
- ArrayList 应用更广泛的动态数组,因为线程不安全,所以性能比较好,也可以自动扩容。Vectory自动扩容一倍,而ArrayList 自动扩容0.5倍。
- LinkedList java提供的双向链表结构 不需要扩容,线程不安全。但是内存管理比较好 ,每次插入只需要new 一个结点。
传送门
java集合框架之Vecotry
java集合框架之LinkedList
java集合框架之ArrayList