Iterator是Java集合框架中用于安全遍历和删除元素的接口,通过hasNext()、next()和remove()方法实现统一访问;使用时需注意remove()调用时机、fail-fast机制及避免遍历中直接修改集合;增强for循环基于Iterator实现,但无法执行删除操作;多线程环境下推荐使用CopyOnWriteArrayList等线程安全集合以避免并发修改异常。

在Java中,Iterator 是集合框架中用于遍历集合元素的核心接口之一。它提供了一种统一的方式来访问集合中的元素,而无需暴露底层的数据结构。正确使用 Iterator 可以提高代码的可读性和安全性,尤其是在遍历过程中需要删除元素时。
Iterator的基本使用方法
Iterator 接口定义了三个主要方法:
- hasNext():判断集合中是否还有下一个元素,返回 boolean 值。
- next():返回当前指向的元素,并将指针移动到下一个位置。
- remove():删除上次调用 next() 返回的元素,只能在 next() 之后调用。
以下是一个典型的使用示例:
Listlist = new ArrayList<>(); list.add("apple"); list.add("banana"); list.add("cherry"); Iterator it = list.iterator(); while (it.hasNext()) { String item = it.next(); System.out.println(item); // 安全删除元素 if ("banana".equals(item)) { it.remove(); } }
这段代码可以安全地遍历并删除符合条件的元素,避免了在遍历中直接调用 list.remove() 导致的 ConcurrentModificationException。
立即学习“Java免费学习笔记(深入)”;
使用Iterator时的注意事项
虽然 Iterator 简单易用,但在实际开发中仍需注意以下几点:
- 不能在 next() 之前调用 remove():否则会抛出 IllegalStateException,因为没有可删除的元素。
- remove() 只能调用一次:在连续两次 remove() 调用之间如果没有调用 next(),也会抛出异常。
- fail-fast机制:大多数集合类的迭代器是 fail-fast 的,意味着如果在迭代过程中有其他线程修改了集合结构(添加、删除元素),会抛出 ConcurrentModificationException。单线程下非法修改也会触发该异常。
- 不支持反向遍历:Iterator 只能从前往后遍历。如需反向遍历,可以使用 ListIterator(仅适用于 List 集合)。
- 遍历时不要直接操作集合:例如在使用 Iterator 遍历时调用集合的 add() 或 remove() 方法,会破坏迭代器状态。
Iterator与增强for循环的关系
Java 中的增强 for 循环(foreach)本质上是基于 Iterator 实现的。下面的代码:
for (String item : list) {
System.out.println(item);
}
会被编译器翻译成使用 Iterator 的形式。因此,在需要删除元素的场景下,增强 for 循环无法直接使用 remove() 操作,应显式使用 Iterator。
并发环境下的替代方案
如果在多线程环境中遍历集合,建议使用线程安全的集合类,如 CopyOnWriteArrayList。它的 Iterator 是弱一致性的,不会抛出 ConcurrentModificationException,因为它基于创建迭代器时的快照进行遍历。
基本上就这些。Iterator 虽然简单,但掌握其行为规则和限制,能有效避免运行时异常,提升程序健壮性。










