首页 > 代码库 > Java笔记-快速失败and安全失败

Java笔记-快速失败and安全失败

参考资料:http://blog.csdn.net/chenssy/article/details/38151189

 

快速失败 fail-fast安全失败 fail-safe
java.util包下面的所有的集合类都是快速失败的java.util.concurrent包下面的所有的类都是安全失败的
快速失败的迭代器会抛出ConcurrentModificationException异常安全失败的迭代器不会抛出ConcurrentModificationException异常。

 

 

快速失败

是指某个线程在迭代vector的时候,不允许其他线程修改该vector的内容,这样迭代器迭代出来的结果就会不准确,如用iterator迭代collection的时候,iterator就是另外起的一个线程,它去迭代collection,如果此时用collection.remove(obj)这个方法修改了collection里面的内容的时候,就会出现ConcurrentModificationException异常,这时候该迭代器就快速失败。

比如HashMap HashSet ArrayList都是快速失败的 

为什么叫快速? 我的理解:在迭代的时候,如果另一个线程修改了里面的内容,就立刻报错,而不是继续迭代。

安全失败

Iterator的安全失败是基于对底层集合做拷贝,因此,它不受源集合上修改的影响。

例如:CopyOnWriterArrayList

ArrayList 的一个线程安全的变体,其中所有可变操作(add、set 等等)都是通过对底层数组进行一次新的复制来实现的。 该类产生的开销比较大,但是在两种情况下,它非常适合使用。
1:在不能或不想进行同步遍历,但又需要从并发线程中排除冲突时。
2:当遍历操作的数量大大超过可变操作的数量时。

 

 

 

Java笔记-快速失败and安全失败