Iterator是Java中用于遍历集合的接口,提供hasNext()、next()和remove()等方法,实现统一遍历、安全删除与懒加载;增强for循环基于其底层实现,且多数Iterator具备fail-fast机制,确保遍历期间结构修改可被及时检测。
在Java中,Iterator 是一种设计模式,也是一种接口,用于遍历集合中的元素。它提供了一种统一的方式来访问集合(如 List、Set、Map 的 values 等)中的每一个元素,而不需要暴露底层的数据结构。理解 Iterator 机制,有助于写出更安全、更灵活的集合遍历代码。
Iterator 接口位于 java.util 包中,核心方法包括:
通过这些方法,可以在不知道集合内部结构的情况下安全地遍历和操作元素。
直接使用 for 循环或增强 for 循环看似更简单,但 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-each)其底层就是基于 Iterator 实现的。例如:
for (String s : list) { System.out.println(s); }
这段代码在编译后会被转换为使用 Iterator 的形式。因此,只要类实现了 Iterable 接口(定义了 iterator() 方法),就可以用于增强 for 循环。
大多数集合的 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 不仅是一个工具,更体现了面向对象中“封装”和“解耦”的思想——让遍历逻辑与数据结构分离,提升代码的健壮性和可维护性。