Iterator用于安全遍历集合,提供hasNext()、next()和remove()方法,支持边遍历边删除,避免ConcurrentModificationException,符合封装原则,且具备fail-fast机制,确保遍历安全。
迭代器 Iterator 是 Java 中用于遍历集合元素的一种方式。它提供了一种统一的方法来访问集合(如 List、Set、Queue 等)中的每一个元素,而不需要关心集合的内部结构。
它主要用于在不暴露集合底层实现的前提下,逐个访问集合中的元素。这种设计符合“封装性”原则,让代码更安全、更灵活。
常见的集合类都实现了 Iterable 接口,这意味着它们可以通过 iterator() 方法获取一个 I
terator 对象。
Iterator 接口中定义了几个关键方法:
使用时通常这样写:
Iteratorit = list.iterator(); while (it.hasNext()) { String item = it.next(); System.out.println(item); }
直接用 for 循环不是更简单吗?但在某些情况下,比如边遍历边删除元素,普通循环容易出错。而 Iterator 提供了安全的删除机制。
例如,在 ArrayList 遍历时直接删除元素会抛出 ConcurrentModificationException,但用 Iterator 的 remove() 方法就可以避免这个问题。
Iterator 是单向的,只能往前走,不能回头或跳转。如果需要双向遍历,可以使用其子接口 ListIterator(仅适用于 List 集合)。
另外,Iterator 失败快速(fail-fast):如果在迭代过程中有其他线程修改了集合结构,大多数实现会立即抛出异常,防止不可预知的行为。
基本上就这些。Iterator 虽然看起来简单,但在集合操作中非常实用,尤其是处理删除逻辑时。掌握它有助于写出更健壮的集合遍历代码。