2024-03-14
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接:https://www.skjava.com/mianshi/baodian/detail/3173900850

fail-safe 机制是 Java 集合中一种错误处理机制,它允许集合在迭代过程中结构被修改而不会抛出ConcurrentModificationException异常。这与 fail-fast 机制是相反的,后者在检测到集合在迭代过程中,如果结构被修改时会立即抛出 ConcurrentModificationException 异常。

fail-safe 机制通过使用并发集合实现,如java.util.concurrent包中提供的集合(ConcurrentHashMap),或通过创建集合的副本来迭代(如CopyOnWriteArrayListCopyOnWriteArraySet),从而避免修改原始集合时产生并发问题。它提供了一种安全的方式来处理并发修改,比较适合多线程场景。

  • ConcurrentHashMap:一个高效的并发HashMap,使用分段锁技术来管理对不同段的并发访问,允许多个读取操作和写入操作并发进行,从而提高性能。
  • CopyOnWriteArrayListCopyOnWriteArraySet:每次修改时都会创建并修改集合的一个副本,读取操作仍然可以安全地访问原始数据。它确保了迭代器在迭代期间看到的是一个不变的快照。
  • 自定义迭代副本:这是一种另类的实现方式,即在迭代集合之前创建其副本,迭代器实际上是在集合的副本上进行操作,原始集合发生修改不影响迭代器的副本。

更多阅读:

什么是fail-fast 机制?

CopyOnWriteArrayList底层原理是什么?

阅读全文