fail-safe
机制是 Java 集合中一种错误处理机制,它允许集合在迭代过程中结构被修改而不会抛出ConcurrentModificationException
异常。这与 fail-fast
机制是相反的,后者在检测到集合在迭代过程中,如果结构被修改时会立即抛出 ConcurrentModificationException
异常。
fail-safe
机制通过使用并发集合实现,如java.util.concurrent
包中提供的集合(ConcurrentHashMap
),或通过创建集合的副本来迭代(如CopyOnWriteArrayList
、CopyOnWriteArraySet
),从而避免修改原始集合时产生并发问题。它提供了一种安全的方式来处理并发修改,比较适合多线程场景。
ConcurrentHashMap
:一个高效的并发HashMap,使用分段锁技术来管理对不同段的并发访问,允许多个读取操作和写入操作并发进行,从而提高性能。CopyOnWriteArrayList
和CopyOnWriteArraySet
:每次修改时都会创建并修改集合的一个副本,读取操作仍然可以安全地访问原始数据。它确保了迭代器在迭代期间看到的是一个不变的快照。自定义迭代副本
:这是一种另类的实现方式,即在迭代集合之前创建其副本,迭代器实际上是在集合的副本上进行操作,原始集合发生修改不影响迭代器的副本。
更多阅读: