Iterator是Java中用于遍历集合的接口,提供hasNext()、next()和remove()等方法,实现统一遍历、安全删除与懒加载;增强for循环基于其底层实现,且多数Iterator具备fail-fast机制,确保遍历期间结构修改可被及时检测。

在Java中,Iterator 是一种设计模式,也是一种接口,用于遍历集合中的元素。它提供了一种统一的方式来访问集合(如 List、Set、Map 的 values 等)中的每一个元素,而不需要暴露底层的数据结构。理解 Iterator 机制,有助于写出更安全、更灵活的集合遍历代码。
Iterator 的基本作用
Iterator 接口位于 java.util 包中,核心方法包括:
- hasNext():判断是否还有下一个元素。
- next():返回下一个元素,并将指针后移。
- remove():删除当前指向的元素(可选操作)。
- forEachRemaining():从当前元素开始,对剩余每个元素执行指定操作。
通过这些方法,可以在不知道集合内部结构的情况下安全地遍历和操作元素。
为什么需要 Iterator?
直接使用 for 循环或增强 for 循环看似更简单,但 Iterator 提供了额外的优势:
立即学习“Java免费学习笔记(深入)”;
- 统一接口:不同集合类(ArrayList、HashSet、LinkedList)都可以用同样的方式遍历。
- 安全删除:在遍历过程中删除元素时,如果直接调用集合的 remove 方法会抛出 ConcurrentModificationException,而使用 Iterator 的 remove() 方法是安全的。
- 延迟计算:某些集合(如 Stream 或大型数据结构)可以按需生成元素,Iterator 支持这种“懒加载”机制。
实际使用示例
以下是一个使用 Iterator 遍历 ArrayList 并删除特定元素的例子:
Listlist = new ArrayList<>(Arrays.asList("a", "b", "c", "d")); Iterator it = list.iterator(); while (it.hasNext()) { String value = it.next(); if ("c".equals(value)) { it.remove(); // 安全删除 } } System.out.println(list); // 输出 [a, b, d]
注意:必须在调用 next() 之后才能调用 remove(),否则会抛出 IllegalStateException。
增强 for 循环背后的机制
我们常用的增强 for 循环(for-each)其底层就是基于 Iterator 实现的。例如:
for (String s : list) {
System.out.println(s);
}
这段代码在编译后会被转换为使用 Iterator 的形式。因此,只要类实现了 Iterable 接口(定义了 iterator() 方法),就可以用于增强 for 循环。
Fail-Fast 机制
大多数集合的 Iterator 具有 fail-fast 特性。这意味着如果在迭代过程中,有其他线程或代码直接修改了集合结构(添加/删除元素),Iterator 会立即抛出 ConcurrentModificationException。这是为了防止数据不一致。
例如:
Listlist = new ArrayList<>(Arrays.asList("a", "b")); Iterator it = list.iterator(); list.add("c"); // 直接修改集合 it.next(); // 此处会抛出 ConcurrentModificationException
要避免这个问题,应始终使用 Iterator 自身的 remove() 方法来修改集合。
基本上就这些。Iterator 不仅是一个工具,更体现了面向对象中“封装”和“解耦”的思想——让遍历逻辑与数据结构分离,提升代码的健壮性和可维护性。










