fail-fast 机制,即快速失败机制,是 Java 集合中的一种错误检测机制。当在迭代集合的过程中,该集合在结构上发生改变的时候,就有可能发生 fail-fast,即抛出 ConcurrentModificationException 异常。fail-fast 机制并不保证在不同步的修改下抛出异常,他只是尽最大努力去抛出,所以这种机制一般仅用于检测 bug。
那么如何解决 fail-fast 呢?
使用 java.util.concurrent 包下的集合来替代。比如使用 CopyOnWriteArrayList 代替 ArrayList,CopyOnWriteArrayList 在使用上和 ArrayList 是一样的。但是它在进行 add 或 remove 操作时,并不是在原数组上修改,而是将原数组拷贝一份,在新数组上进行修改,待完成后,才将旧数组的引用指向新数组。所以对于 CopyOnWriteArrayList 来说,在迭代过程中并不会发生 fail-fast 现象。