贝利信息

在Java中List接口有哪些实现_JavaList常用实现类对比

日期:2026-01-08 00:00 / 作者:P粉602998670
ArrayList基于数组、查询快增删慢;LinkedList基于链表、首尾增删快但随机访问慢;Vector线程安全但性能低已过时;CopyOnWriteArrayList读多写少并发安全。

ArrayList:基于数组的动态列表

ArrayList 是最常用的 List 实现,底层用 Object 数组存储元素,支持随机访问,查询快(O(1)),增删慢(尤其是中间位置,需移动元素,平均 O(n))。它线程不安全,但性能高,适合读多写少、按索引频繁访问的场景。

使用建议:

LinkedList:基于双向链表的列表

LinkedList 底层是双向链表节点,不支持真正意义上的随机访问(get(i) 需从头或尾遍历,O(n)),但首尾插入/删除极快(O(1))。它同时实现了 Queue 和 Deque 接口,可作栈、队列使用。

使用建议:

Vector:线程安全但过时的动态数组

Vector 和 ArrayList 结构类似(数组实现),但所有 public 方法都加了 synchronized,因此线程安全。但同步粒度粗、性能低,且 API 设计陈旧(如 elementAt()、firstElement() 等)。

使用建议:

CopyOnWriteArrayList:读多写少的并发列表

底层每次写操作(add、set、remove)都会复制整个数组,读操作无锁、完全并发安全。适用于读极其频繁、写极少(如监听器列表、配置项缓存)的场景。

使用建议: