Collections.synchronizedList通过同步代理确保单个操作线程安全,使用实例锁保护add、get等方法;2. 迭代需手动加锁防止ConcurrentModificationException;3. 复合操作如检查再添加必须显式同步;4. 适用于低并发,高并发推荐CopyOnWriteArrayList。

Java 中的 Collections.synchronizedList 通过将集合操作包装在同步代码块中来保证线程安全。它返回一个由原列表支持、但所有公共方法都使用 synchronized 关键字加锁的列表。
基本原理:同步包装器
该方法不修改原始列表本身,而是返回一个“同步代理”对象。这个代理对象封装了原始列表,并确保每个对外暴露的方法调用都进行线程同步:
- 内部使用 this 作为锁对象(即实例级别的锁)
- 对 add、get、set、remove、size 等方法都加上 synchronized 修饰
- 每次访问或修改列表内容时,必须先获取对象锁
正确使用迭代器
即使列表被同步,其迭代器也不是自动线程安全的。遍历时必须手动同步:
Listlist = Collections.synchronizedList(new ArrayList<>()); // ... synchronized (list) { for (String item : list) { System.out.println(item); } }
如果不加 synchronized 块,可能在遍历过程中其他线程修改列表,导致 ConcurrentModificationException。
立即学习“Java免费学习笔记(深入)”;
复合操作需要额外同步
像“检查再添加”这类多步操作无法靠 synchronizedList 自动保障原子性:
synchronized (list) {
if (!list.contains("value")) {
list.add("value");
}
}
必须显式使用 synchronized 块包裹整个逻辑段,以防止中间状态被其他线程干扰。
基本上就这些。synchronizedList 提供基础线程安全能力,适合低并发场景。高并发下推荐使用 CopyOnWriteArrayList 或显式使用并发容器和锁机制。关键点在于理解它只保证单个方法调用的安全,不提供整体操作的原子性。










