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

本文讨论了fail-safe和fail-fast在多线程并发环境中的作用,前者快速抛出异常确保数据一致性,后者保证安全但不阻断修改。Java中如HashMap和ArrayList使用fail-fast机制,而CopyOnWriteArrayList和ConcurrentHashMap则是fail-safe机制的实例。
(mic老师版面试题)
前段时间一个小伙伴去面试,遇到这样一个问题。
”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 等。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值