fail-safe 机制与 fail-fast 机制分别有什么作用

fail-safe 机制与 fail-fast 机制分别有什么作用

fail-safe 和 fail-fast,是多线程并发操作集合时的一种失败处理机制。


Fail-fast: 表示快速失败,在集合遍历过程中,一旦发现容器中的数据被修改了, 会立刻抛出 ConcurrentModificationException 异常,从而导致遍历失败,像这种情况。

一般会配合迭代器中使用,比如定义一个 Map 集合,使用 Iterator 迭代器进行数据遍历,在遍历过程中,对集合数据做变更时,就会发生 fail-fast。

java.util 包下的集合类都是快速失败机制的。

常见的的使用 fail-fast 方式遍历的容 器有 HashMap 和 ArrayList 等。


Fail-safe: 表示失败安全,也就是在这种机制下,出现集合元素的修改,不会抛出ConcurrentModificationException

原因是采用安全失败机制的集合容器,在遍历时不是直接在集合内容上访问的, 而是先复制原有集合内容, 在拷贝的集合上进行遍历。

由于迭代时是对原集合的拷贝进行遍历,所以在遍历过程中对原集合所作的修改并不能被迭代器检测到,比如,定义了一个 CopyOnWriteArrayList,在对这个集合遍历过程中,对集合元素做修改后,不会抛出异常,但同时也不会打印出增加的元素。

java.util.concurrent 包下的容器都是安全失败的,可以在多线程下并发使用,并发修改。

常 见 的 的 使 用 fail-safe 方 式 遍 历 的 容 器 有 ConcerrentHashMap 和 CopyOnWriteArrayList 等。


猜你喜欢

转载自blog.csdn.net/weixin_47410172/article/details/127766917
今日推荐