什么是fail-safe?
fail-safe(安全失败)机制在遍历时不是直接在集合内容上访问的,而是先复制原有集合内容,在拷贝的集合上进行遍历,因此它不会抛出java.util.ConcurrentModificationException异常。
java.util.concurrent包下的集合都是 fail-safe安全失败的,可以在多线程下并发使用,并发修改。
什么是fail-fast?
fail-fast(快速失败)机制是Java集合(Collection)中的一种错误机制.
当多个线程对同一个集合的内容进行操作时,就可能会产生fail-fast事件.
例如:当某一个线程A通过iterator迭代器去遍历某集合的过程中,如果集合对象的内容进行了修改(增如、删除、修改)则会抛出ConcurrentModification Exception产生fail-fast事件.
java.util包下的集合类都是快速失败的,不能在多线程下发生并发修改(迭代过程中被修改)。
fail-safe与fail-fast有什么区别
Java.util包中的所有集合类都被设计为fail-fast(快速失败)
java.util.concurrent 中的集合类都为fail-safe(安全失败)的。
Fail-fast迭代器抛出ConcurrentModificationException
Fail-safe迭代器从不抛出ConcurrentModificationException