使用同步包装类、并发集合类或显式锁可实现Java多线程下集合的线程安全,优先推荐ConcurrentHashMap和CopyOnWriteArrayList以兼顾性能与安全性。

在Java中进行多线程环境下的集合操作时,确保线程安全是关键。多个线程同时读写同一个集合可能导致数据不一致、异常甚至程序崩溃。要实现安全的并发集合操作,主要有以下几种方式。
使用同步包装类(Collections.synchronizedXxx)
Java提供了Collections.synchronizedList、synchronizedMap等工具方法,可以将普通集合转换为线程安全的集合。
示例:
Listlist.add("item1"); // 安全
注意:虽然集合本身是同步的,但遍历时仍需手动加锁,否则可能抛出ConcurrentModificationException。
立即学习“Java免费学习笔记(深入)”;
例如遍历:
synchronized(list) {for (String item : list) {
System.out.println(item);
}
}
使用并发集合类(java.util.concurrent包)
更推荐的方式是使用java.util.concurrent包中的专用并发集合,它们在设计上就支持高并发,性能优于同步包装类。
- ConcurrentHashMap:线程安全的Map,支持高并发读写,比Collections.synchronizedMap性能更好。
- CopyOnWriteArrayList:适用于读多写少的场景,每次修改都会复制底层数组,保证读操作无锁安全。
- BlockingQueue 实现如 LinkedBlockingQueue:用于生产者-消费者模型,自动处理线程阻塞与唤醒。
示例:
ConcurrentHashMapmap.put("key1", 100);
Integer val = map.get("key1"); // 安全读取
使用显式同步控制(synchronized或Lock)
如果需要对一组操作保持原子性,比如“检查再插入”,即使使用并发集合也可能需要额外加锁。
例如:
synchronized(list) {if (!list.contains("item")) {
list.add("item");
}
}
或者使用ReentrantLock进行更细粒度的控制:
Lock lock = new ReentrantLock();lock.lock();
try {
list.add("safe item");
} finally {
lock.unlock();
}
基本上就这些。选择哪种方式取决于具体场景:一般情况优先使用ConcurrentHashMap或CopyOnWriteArrayList,避免手动同步带来的复杂性和性能损耗。并发编程中,正确性和性能都要兼顾,合理选用工具是关键。










