“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机制一定会发生。
相关推荐
在Java编程语言中,`...综上所述,`Enumeration`和`Iterator`接口在功能、并发安全性以及历史背景方面都有明显的区别。在新的开发项目中,通常选择使用`Iterator`,以利用其提供的更强大功能和更现代的编程模型。
8. **Enumeration和Iterator接口的区别?** Enumeration仅存在于早期的Java版本,用于遍历Vector和Hashtable。Iterator提供更强大的功能,如删除元素,且在集合框架中更为普遍。 9. **为何没有像Iterator.add()...
- **Fail-safe**:某些集合如`ConcurrentHashMap`和`CopyOnWriteArrayList`提供了一种线程安全的遍历机制,即使遍历过程中集合被修改也不会抛出异常。 - 实现机制:通过创建集合的副本进行遍历,这样就不会受到集合...
2.15 快速失败(fail-fast)和安全失败(fail-safe) - 快速失败机制检测到另一个线程在修改集合时会立即抛出ConcurrentModificationException。 - 安全失败机制则是通过创建集合的副本来进行迭代。 三.锁 Java提供了...
在Java集合框架中,有两种迭代机制:“快速失败”(fail-fast)和“安全失败”(fail-safe)。快速失败机制是Java集合的默认行为,当集合在迭代过程中被修改(非迭代器自身进行的修改),会抛出`...
在遍历机制上,HashMap使用了Java的Iterator作为迭代器,这是一种fail-fast机制,当其他线程修改了Map结构时,迭代器会抛出ConcurrentModificationException。相比之下,HashTable使用了老式的Enumeration,它不支持...
与`HashTable`的`Enumeration`相比,`Iterator`支持fail-fast机制,即当集合在迭代过程中被修改时(除了通过迭代器自身的`remove()`方法),会立即抛出`ConcurrentModificationException`。然而,`HashTable`的`...
27. **什么是迭代器的fail-fast机制?** 如果在迭代过程中集合结构被修改(如添加、删除元素),迭代器会抛出ConcurrentModificationException。 28. **什么是Java的并发容器?** 如ConcurrentHashMap、...