fail-fast快速失败机制分析
来源:互联网 发布:网络推广是做什么的 编辑:程序博客网 时间:2024/06/06 01:02
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的区别
Fail-fast
Fail-safe
ConcurrentModificationException
Yes
No
Clone object
No
Yes
Memory overhead
No
yes
Examples
HashMap ArrayList
HashSet Vector
CopyOnWriteArrayList
concurrentHashMap
- fail-fast快速失败机制分析
- java中的fail-fast(快速失败)机制
- fail-fast(快速失败/报错机制)-ConcurrentModificationException
- Java学习笔记 14 快速失败fail-fast机制
- 快速失败(fail-fast)和安全失败(fail-safe)
- “快速失败”也就是fail-fast,Java集合的一种错误检测机制。
- HashMap迭代过程中fail-fast 机制失败经历!!
- java中的快速失败(fail-fast)与安全失败(fail-safe)
- java中的快速失败(fail-fast)与安全失败(fail-safe)
- fail-fast机制
- Fail-fast机制
- Fail Fast机制
- fail-fast机制
- Fail-Fast 机制
- fail-fast机制
- fail-fast机制
- fail-fast机制
- Java fast-fail机制
- Kanade's sum 2017多校#3 链表
- 调用Graphics.FromImage()出现OutofMemory的异常
- 网络编程的原理(端口与服务器互相对话)
- uva 11988 Broken Keyboard (a.k.a. Beiju Text)
- hdu 6092 Rikka with Subset
- fail-fast快速失败机制分析
- 银色 MacBook Pro 13.3笔记本
- C语言文件常用操作
- vsftpd简易配置攻略
- 【感悟】本书书名无法描述本书内容(一)
- Python学习笔记·Python语法元素
- JFinal之旅——Sql 管理与动态生成实现简洁分页
- Java-Preferences用法-入门
- Apache Kafka:大数据的实时处理时代