Collections.synchronizedList可将普通List包装为线程安全的同步List,所有读写操作自动加锁,确保多线程下数据一致性;但遍历时需手动使用synchronized块同步,否则可能引发ConcurrentModificationException。
在多线程环境下操作List时,如果List本身不是线程安全的(如ArrayList),就可能出现数据不一致、抛出异常等问题。Java提供了多种方式来保证List的线程安全,其中Collections.synchronizedList是一种简单有效的解决方案。
它是java.util.Collections类中的一个静态方法,可以将任意List包装成线程安全的同步List。该方法返回一个被同步代理包装过的List,所有对它的读写操作都会自动加上同步锁(synchronized),从而防止多个线程同时修改导致的问题。
基本用法示例:
List此时的list就是线程安全的,可以在多线程中安全地添加、删除和访问元素。
虽然synchronizedList保证了单个操作的线程安全,但在遍历(迭代)时仍需手动加锁,否则可能抛出ConcurrentModificationException。
正确遍历方式:
synchronized (list) { for (String item : list) { System.out.println(item); } }因为iterator本身没有被同步,所以必须显式使用synchronized块包围迭代过程,锁住list对象本身。
比如,在频繁遍历且偶尔插入的场景下,CopyOnWriteArrayList可能更合适;而在需要高度控制同步逻辑时,synchronizedList配合手动锁仍是实用选择。
例如:
List基本上就这些。Collections.synchronizedList提供了一种快速实现线程安全List的方式,关键是记住:单个操作是安全的,但复合操作和遍历仍需额外同步。用好它,能在不少项目中省去手动加锁的麻烦。