Iterator是Java中遍历集合的标准方式,通过hasNext()和next()方法实现元素访问,使用remove()可在遍历时安全删除元素;直接调用集合的remove()会触发ConcurrentModificationException;增强for循环底层基于Iterator实现,适用于只读遍历;Iterator采用fail-fast机制,多线程修改时需使用线程安全集合如CopyOnWriteArrayList。

在Java中,Iterator 是用于遍历集合元素的标准方式之一。它提供了一种统一的方法来访问List、Set、Queue等集合中的元素,而不需要关心集合的内部结构。
一、Iterator的基本使用方法
要使用Iterator遍历集合,需通过集合的 iterator() 方法获取迭代器对象。然后利用其提供的方法进行遍历。
示例代码:
List
list.add("apple");
list.add("banana");
list.add("orange");
Iterator
while (it.hasNext()) {
String item = it.next();
System.out.println(item);
}
常用方法说明:
- hasNext():判断是否还有下一个元素,返回boolean值。
- next():返回当前指向的元素,并将指针移动到下一个位置。
- remove():删除最后一次调用next()所返回的元素,可在遍历时安全删除元素。
二、使用Iterator删除元素的注意事项
在遍历集合时直接调用集合本身的 remove() 方法会抛出 ConcurrentModificationException 异常,因为这会导致结构被修改。正确做法是使用Iterator的 remove() 方法。
立即学习“Java免费学习笔记(深入)”;
正确删除示例:
Iterator
while (it.hasNext()) {
String item = it.next();
if ("banana".equals(item)) {
it.remove(); // 安全删除
}
}
注意点:
- 必须先调用 next() 才能调用 remove(),否则会抛出 IllegalStateException。
- 不能连续两次调用 remove() 而不调用 next(),也会报错。
三、增强for循环与Iterator的关系
Java中的增强for循环(foreach)底层实际上就是使用Iterator实现的,适用于大多数遍历场景。
等价写法对比:
// 使用foreach
for (String item : list) {
System.out.println(item);
}
// 编译后相当于:
Iterator
while (it.hasNext()) {
String item = it.next();
System.out.println(item);
}
如果只是遍历读取数据,推荐使用增强for循环,代码更简洁;若需要在遍历中删除元素,则应显式使用Iterator。
四、Fail-Fast机制与并发修改问题
大多数Java集合类(如ArrayList、HashMap)的Iterator采用fail-fast机制。这意味着当Iterator创建后,如果有其他操作修改了集合结构(添加或删除元素),就会抛出 ConcurrentModificationException。
避免方式:
- 遍历时如需修改,仅通过Iterator的 remove() 方法操作。
- 在多线程环境下,应使用线程安全的集合类,如 CopyOnWriteArrayList 或使用同步控制。
例如,CopyOnWriteArrayList 的Iterator不会抛出ConcurrentModificationException,因为它基于快照遍历,适合读多写少的并发场景。
基本上就这些。Iterator是集合遍历的基础工具,理解其原理和限制对编写安全、稳定的Java代码很有帮助。










