快速失败与安全失败

快速失败:
在使用迭代器对集合进行迭代的过程中,如果a线程正在对集合进行遍历,而b线程正在对集合进行修改,又或者a在遍历的过程中对集合进行修改,都将导致a线程抛出ConcurrentModificationException异常。
迭代器初始化时会将modCount 变量(表示修改次数)赋值给expectedModCount变量。集合在被遍历期间如果内容发生变化,就会改变modCount的值。每当迭代器使用hashNext()/next()遍历下一个元素之前,都会判断modCount变量是否为expectedModCount值,是的话就继续遍历;否则抛出异常,终止遍历。

安全失败:
采用安全失败的集合容器,在进行遍历的时候不是对原数据进行遍历,而是拷贝一份数据的副本,在这个副本上进行遍历,如果在遍历的过程中修改了值,将不会抛出异常,因为修改的是副本的值,对原数据没有任何影响。

java.util包的集合类都是快速失败的,而java.util.concurrent(并存的,同时发生的;即并发包)下的类都是安全失败的