JAVA面试题之LinkedList ArrayList Vectory 的区别

首先 这三者都实现了java集合框架List 所谓的有序集合,因此具体功能比较相似,比如提供定位,添加,删除的操作。都提供迭代器遍历,但是因为具体的设计区别在行为,性能,线程安全等方向又有很大的不同。

  • Vector 是java早期提供线程安全的动态数组,如果不需要线程安全,不建议选择。同步有额外的开销,Vectory内部使用对象数组来保存数据的,可以根据需要自动增加容量,当数组已满会创建新的数组,并拷贝原数组。
  • ArrayList 应用更广泛的动态数组,因为线程不安全,所以性能比较好,也可以自动扩容。Vectory自动扩容一倍,而ArrayList 自动扩容0.5倍。
  • LinkedList java提供的双向链表结构 不需要扩容,线程不安全。但是内存管理比较好 ,每次插入只需要new 一个结点。

传送门
java集合框架之Vecotry
java集合框架之LinkedList
java集合框架之ArrayList

发布了18 篇原创文章 · 获赞 5 · 访问量 381

猜你喜欢

转载自blog.csdn.net/qq_41050869/article/details/104565767