面经-Iterator_FailFast_FailSafe

1.failFast

(ArrayList)

一旦发现遍历的同时其他人来修改,则立即抛异常。

当执行一个遍历时,另一个线程修改了遍历的数据,则会立即抛出ConcurrentModificationException(并发修改异常)。

 

实现原理:记录了循环开始时的次数,如果在循环的过程中修改次数被改,则会尽快失败,抛出异常,阻止循环继续。

 

2.failSafe

(CopyWriteArrayList)

发现遍历的同时其他人来修改,应当能有应对策略,例如牺牲一致性来让整个遍历运行完成。

第一次遍历打印出来的依然是旧的循环,第二次遍历才会更新。

 

实现原理:读写分离。遍历时使用旧数组,在元素增加时创建一个新数组,长度是旧数组长度+1,然后将旧数组的元素copy到新数组中。添加是一个数组,遍历是另一个数组,互不干扰。遍历结束后回收旧数组,替换成新数组,于是在下次遍历的时候就遍历新的(添加后的)数组。

 

 



 
posted @ 2022-08-22 11:36  临易  阅读(18)  评论(0编辑  收藏  举报