Iterator和Enumeration 区别 fail-fast 机制
“Iterator(迭代器)” 或 “Enumeration(枚举类)” 都可以遍历集合,Iterator和Enumeration都是接口,主要区别在于接口数、fail-fast机制:
(01) 函数接口不同:Enumeration只有2个函数接口。通过Enumeration,我们只能读取集合的数据,而不能对数据进行修改。
Iterator只有3个函数接口。Iterator除了能读取集合的数据之外,也能数据进行删除操作。
(02) Iterator支持fail-fast机制,而Enumeration不支持。Enumeration 是JDK 1.0添加的接口。使用到它的函数包括Vector、Hashtable等类,这些类都是JDK 1.0中加入的,Enumeration存在的目的就是为它们提供遍历接口。Enumeration本身并没有支持同步,而在Vector、Hashtable实现Enumeration时,添加了同步。
而Iterator 是JDK 1.2才添加的接口,它也是为了HashMap、ArrayList等集合提供遍历接口。Iterator是支持fail-fast机制的:当多个线程对同一个集合的内容进行操作时,就可能会产生fail-fast事件。
fail-fast 机制是java集合(Collection)中的一种错误机制。当多个线程对同一个集合的内容进行操作时,就可能会产生fail-fast事件。
例如:当某一个线程A通过iterator去遍历某集合的过程中,若该集合的内容被其他线程所改变了;那么线程A访问集合时,就会抛出ConcurrentModificationException异常,产生fail-fast事件。
fail-fast机制,是一种错误检测机制。它只能被用来检测错误,因为JDK并不保证fail-fast机制一定会发生。
- List和Set集合中iterator的fail-fast特性之区别
- 基础概念:fail-fast(快速失败) 与 fail-safe(安全失败) 机制有什么区别
- fail-fast 与 fail-safe 机制有什么区别
- Iterator与fast-fail机制
- java Iterator Fail-fast机制
- 【JDK源码】ArrayList线程不安全详解—Fail-Fast机制总结
- fail-fast机制(遍历的同时删除List中的对象)
- fail-fast机制
- java中fail-fast 和 fail-safe的区别
- fail-fast机制
- java Collecttion的fail-fast的产生原因和处理方式 以及java中fail-fast 和 fail-safe的区别
- 快速失败机制--fail-fast
- Java基础之容器之fail-fast机制
- fail-fast机制
- Enumeration接口和Iterator接口的区别
- Enumeration和Iterator的区别
- java中的fail-fast(快速失败)机制
- Java:fail-fast 机制
- Java学习笔记 14 快速失败fail-fast机制
- Enumeration和Iterator的区别