ConcurrentHashMap适用于高并发读写Map场景,采用分段锁或CAS+synchronized提升性能;CopyOnWriteArrayList适用于读多写少的List操作,通过写时复制保证线程安全,但写开销大。

在多线程环境下,集合类的线程安全问题至关重要。Java 提供了多种并发集合类来解决这个问题,其中 ConcurrentHashMap 和 CopyOnWriteArrayList 是两个常用且高效的线程安全集合实现。它们分别适用于不同的并发场景,合理使用可以显著提升程序性能和安全性。
ConcurrentHashMap:高并发下的线程安全Map
ConcurrentHashMap 是 HashMap 的线程安全版本,相比早期的 Collections.synchronizedMap(),它通过分段锁(JDK 1.7)或 CAS + synchronized(JDK 1.8 及以后)机制提高了并发访问效率。
使用建议:
- 适合读多写少、高并发的键值对存储场景。
- 支持并发读取,无需加锁;写操作只锁定特定桶,不影响其他线程读取。
- 不允许多个线程同时修改同一个 key 而不加同步控制,需业务逻辑配合。
ConcurrentHashMapmap = new ConcurrentHashMap<>(); map.put("count", 1); map.computeIfPresent("count", (k, v) -> v + 1); // 原子性更新 Integer value = map.get("count");
CopyOnWriteArrayList:读操作完全无锁的线程安全List
CopyOnWriteArrayList 是 ArrayList 的线程安全变体,采用“写时复制”策略。每次修改都会创建一个新的底层数组,原数组供正在遍历的线程继续使用。
立即学习“Java免费学习笔记(深入)”;
适用场景:
- 适用于读远多于写的场景,比如监听器列表、事件订阅列表。
- 迭代过程中不会抛出 ConcurrentModificationException。
- 写操作开销大,频繁修改时不推荐使用。
CopyOnWriteArrayListlist = new CopyOnWriteArrayList<>(); list.add("item1"); list.add("item2"); // 多线程遍历时安全 for (String item : list) { System.out.println(item); }
如何选择合适的并发集合?
根据实际业务需求选择正确的集合类型是关键:
- 需要高性能的并发 Map 操作,优先选 ConcurrentHashMap。
- 如果 List 主要是读操作,偶尔添加元素,CopyOnWriteArrayList 是理想选择。
- 避免在 CopyOnWriteArrayList 中频繁删除或插入大量数据。
- 注意迭代器返回的是快照,不会反映实时修改。
基本上就这些。理解这两个类的设计原理和使用边界,能有效避免并发问题,同时保持良好的性能表现。不复杂但容易忽略细节。










