fail-fast快速失败机制分析
2017-08-08 20:50
411 查看
Fail-fast总结:
1. Fail-fast机制式java集合中的一种异常机制。当多个线程对同一个集合的内容进行操作时,就可能会产生fail-fast。抛出java.util.ConcurrentModificationException异常时,也即产生fail-fast事件
2. Fail-fast机制,是一种错误检测机制。它只能被用来检测错误,因为JDK并不保证fail-fast机制一定会发生。若在多线程环境下使用fail-fast机制的集合,建议使用java.util.concurrent包下的的类去取代java.util包下的类。
3. Fail-fast原理
产生fail-fast事件,是通过抛出ConcurrentModificationException异常来触发的。
那么,ArrayList是如何抛出ConcurrentModificationException异常的呢? 我们知道,ConcurrentModificationException是在操作Iterator时抛出的异常。若modCount不等于expectedModCount,则抛出ConcurrentModificationException异常,产生fail-fast机制。
Fail-fast是如何产生的?
当多个线程对同一个集合进行操作的时候,某线程访问集合的过程中,该集合的内容被其他线程所改变(即其它线程通过add、remove、clear等方法,改变了modCount的值);这时,就会抛出ConcurrentModificationException异常,产生fail-fast事件。
Fail-fast和fail-safe的区别
1. Fail-fast机制式java集合中的一种异常机制。当多个线程对同一个集合的内容进行操作时,就可能会产生fail-fast。抛出java.util.ConcurrentModificationException异常时,也即产生fail-fast事件
2. Fail-fast机制,是一种错误检测机制。它只能被用来检测错误,因为JDK并不保证fail-fast机制一定会发生。若在多线程环境下使用fail-fast机制的集合,建议使用java.util.concurrent包下的的类去取代java.util包下的类。
3. Fail-fast原理
产生fail-fast事件,是通过抛出ConcurrentModificationException异常来触发的。
那么,ArrayList是如何抛出ConcurrentModificationException异常的呢? 我们知道,ConcurrentModificationException是在操作Iterator时抛出的异常。若modCount不等于expectedModCount,则抛出ConcurrentModificationException异常,产生fail-fast机制。
Fail-fast是如何产生的?
当多个线程对同一个集合进行操作的时候,某线程访问集合的过程中,该集合的内容被其他线程所改变(即其它线程通过add、remove、clear等方法,改变了modCount的值);这时,就会抛出ConcurrentModificationException异常,产生fail-fast事件。
Fail-fast和fail-safe的区别
| Fail-fast | Fail-safe |
ConcurrentModificationException | Yes | No |
Clone object | No | Yes |
Memory overhead | No | yes |
Examples | HashMap ArrayList HashSet Vector | CopyOnWriteArrayList concurrentHashMap |
相关文章推荐
- Java集合(16)--快速失败机制(Fail-Fast)
- java中的fail-fast(快速失败)机制
- Java学习笔记 14 快速失败fail-fast机制
- 快速失败机制--fail-fast
- fail-fast(快速失败/报错机制)-ConcurrentModificationException
- 快速失败fail-fast机制
- Java集合框架中的快速失败(fail—fast)机制
- 快速失败(fail-fast)和安全失败(fail-safe)的区别
- 快速失败(fail-fast)和安全失败(fail-safe)
- ArrayList源码分析(fail-fast机制和扩容)
- java中的快速失败(fail-fast)与安全失败(fail-safe)
- 快速失败(fail-fast)和安全失败(fail-safe)
- HashMap迭代过程中fail-fast 机制失败经历!!
- 快速失败(fail-fast)和安全失败(fail-safe)(最容易懂!!!)
- java中的快速失败(fail-fast)与安全失败(fail-safe)
- java源码分析之集合框架 fail-fast机制06
- 快速失败(fail-fast)和安全失败(fail-safe)(最容易懂!!!)
- Java中的fail-fast机制
- 大杂烩 -- Java中Iterator的fast-fail分析
- Java-ArrayList快速失败机制/CopyOnWriteArrayList/扩容