fail-fast:
快速失败。fail-fast 机制是Java集合(Collection)中的一种错误机制。 在用迭代器遍历一个集合对象时,如果遍历过程中对集合对象的结构进行了修改(增加、删除),则会抛出Concurrent Modification Exception(并发修改异常)。
这是HashMap集合的机制,如果在循环Map集合时去改变集合的数据,就会报出ConcurrentModifitionException错误。
原理:源码中实现是通过modCount实现,modCount就是修改次数的意思,每次对HashMap的内容进行修改就会增加modCount的值,在迭代器初始化的过程中会将这个值传给迭代器的exceptionModCount,迭代过程中,进行两值的判断相等,不相等在报出Concurrent Modification Exception异常。
fail-safe:
与fail-fast相反,如果模块遇到某种错误,不应该让程序失败,而是采取某种降级策略,尽量往下走。这个原则主要适用于主模块内的分支流程。
fail-safe机制
采用安全失败机制的集合容器,在遍历时不是直接在集合内容上访问的,而是先复制原有集合内容,在拷贝的集合上进行遍历。
原理:由于迭代时是对原集合的拷贝进行遍历,所以在遍历过程中对原集合所作的修改并不能被迭代器检测到,所以不会触发Concurrent Modification Exception。
如果你使用null值,就会使得其无法判断对应的key是不存在还是为空,因为你无法再调用一次contain(key)来对key是否存在进行判断,ConcurrentHashMap同理。