news 2026/2/10 7:36:25

java基础-Iterator 接口

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
java基础-Iterator 接口

Java 中的Iterator 接口是 Java 集合框架(Java Collections Framework)中的一个核心接口,用于遍历集合中的元素。它提供了一种统一的方式来访问集合中的元素,而不需要暴露集合的内部结构。

1.Iterator 接口的主要方法

public interface Iterator<E> { // 检查是否还有下一个元素 boolean hasNext(); // 返回下一个元素 E next(); // 删除当前元素(可选操作) default void remove(); // JDK 8+ 新增:对剩余元素执行操作 default void forEachRemaining(Consumer<? super E> action); }

2.基本使用示例

import java.util.*; public class IteratorExample { public static void main(String[] args) { List<String> list = Arrays.asList("Apple", "Banana", "Cherry"); Iterator<String> iterator = list.iterator(); // 遍历集合 while (iterator.hasNext()) { String fruit = iterator.next(); System.out.println(fruit); } } }

3.在循环中的使用

传统 while 循环

Iterator<String> it = list.iterator(); while (it.hasNext()) { String element = it.next(); // 处理元素 }

使用 for-each 循环(底层使用 Iterator)

for (String element : list) { // 处理元素 }

forEachRemaining 方法(Java 8+)

Iterator<String> it = list.iterator(); it.forEachRemaining(element -> { System.out.println(element); });

4.remove() 方法的使用

List<Integer> numbers = new ArrayList<>(Arrays.asList(1, 2, 3, 4, 5)); Iterator<Integer> it = numbers.iterator(); while (it.hasNext()) { Integer num = it.next(); if (num % 2 == 0) { // 删除偶数 it.remove(); // 安全删除当前元素 } } // numbers 现在包含 [1, 3, 5]

重要:必须先调用next()再调用remove(),且不能连续调用两次remove()

5.ListIterator(增强版 Iterator)

ListIterator扩展了Iterator,支持双向遍历和修改操作:

List<String> list = new ArrayList<>(Arrays.asList("A", "B", "C")); ListIterator<String> listIterator = list.listIterator(); // 向前遍历 while (listIterator.hasNext()) { System.out.println(listIterator.next()); } // 向后遍历 while (listIterator.hasPrevious()) { System.out.println(listIterator.previous()); } // 添加和修改元素 listIterator.add("D"); listIterator.set("E");

6.实现自定义 Iterator

class FixedSizeList<T> implements Iterable<T> { private T[] array; private int size; public FixedSizeList(T[] array) { this.array = array; this.size = array.length; } @Override public Iterator<T> iterator() { return new Iterator<T>() { private int currentIndex = 0; @Override public boolean hasNext() { return currentIndex < size; } @Override public T next() { if (!hasNext()) { throw new NoSuchElementException(); } return array[currentIndex++]; } @Override public void remove() { throw new UnsupportedOperationException("Remove not supported"); } }; } }

7.与 Stream API 的比较(Java 8+)

// 使用 Iterator Iterator<String> it = list.iterator(); while (it.hasNext()) { String s = it.next(); if (s.startsWith("A")) { System.out.println(s); } } // 使用 Stream API(更现代) list.stream() .filter(s -> s.startsWith("A")) .forEach(System.out::println);

8.最佳实践和注意事项

  1. 并发修改异常

    List<String> list = new ArrayList<>(); list.add("A"); list.add("B"); // 错误示例:会抛出 ConcurrentModificationException for (String s : list) { if ("B".equals(s)) { list.remove(s); // 直接修改原集合 } } // 正确示例:使用 Iterator 的 remove() Iterator<String> it = list.iterator(); while (it.hasNext()) { if ("B".equals(it.next())) { it.remove(); // 安全删除 } }
  2. 性能考虑:对于ArrayList,Iterator 遍历和 for 循环性能相似;对于LinkedList,Iterator 性能更好。

  3. 不可逆性:普通 Iterator 只能向前遍历,如果需要双向遍历,使用ListIterator

  4. 线程安全:Iterator 不是线程安全的,在多线程环境下需要同步或使用并发集合。

9.常见实现类

集合类Iterator 实现特点
ArrayList快速随机访问
LinkedList优化顺序访问
HashSet无序遍历
TreeSet有序遍历
HashMap.keySet()遍历键

总结:Iterator 提供了一种标准化的遍历集合的方式,是 Java 集合框架的基础组件。在现代 Java 开发中,虽然 Stream API 提供了更强大的功能,但 Iterator 在简单遍历和某些特定场景下仍然非常有用。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/7 9:33:55

CLAUDE.md - 让AI理解你的项目的秘密武器

CLAUDE.md - 让AI理解你的项目的秘密武器核心观点&#xff1a;一个写得好的CLAUDE.md可以将Claude Code的生产力提升50-100%&#xff0c;这是上下文管理中最高效的投资。 关键词&#xff1a;CLAUDE.md、上下文管理、项目文档、Claude Code配置、工作流优化导读 你将学到&#x…

作者头像 李华
网站建设 2026/2/4 9:54:10

前端面试真的很水,就这38页纸,熬夜背吧!

有没有觉得前端面试越准备越懵&#xff1f;岗位JD写得花里胡哨&#xff0c;实际面起来全是翻来覆去的基础题、高频八股&#xff0c;甚至有些面试官自己都没吃透原理&#xff0c;就照着题库照本宣科。说前端面试“水”&#xff0c;其实就是这个道理——门槛看着低&#xff0c;考…

作者头像 李华
网站建设 2026/2/8 17:54:57

前端向架构突围系列 - 工程化(五):企业级脚手架的设计与落地

写在前面 很多团队都有一个“规范文档”&#xff0c;它通常静静地躺在 Wiki 的角落里&#xff0c;只有新员工入职的第一天会被打开&#xff0c;然后迅速被遗忘。 依靠文档约束人性的规范&#xff0c;注定是失败的。 在架构师的眼里&#xff0c;规范不应该是一个文档&#xff0c…

作者头像 李华
网站建设 2026/2/7 1:07:50

今天我终于明白了:为啥老程序员都不爱带新人

最近在准备前端面试时&#xff0c;被一道基础题难住了&#xff1a;“请手写防抖函数&#xff0c;兼容边界场景并说明在项目中怎么用”。我翻了不少资料才弄懂&#xff0c;转头就跟身边的老程序员吐槽“这题对新人也太不友好了”&#xff0c;结果他一句话点醒我&#xff1a;“不…

作者头像 李华
网站建设 2026/2/8 16:18:27

Altium Designer内PCB走线电流关系图解说明

走线宽度怎么定&#xff1f;别再靠猜了——Altium Designer中PCB载流能力的科学设计法你有没有遇到过这种情况&#xff1a;板子打回来一上电&#xff0c;某段电源走线“滋”地冒烟&#xff0c;芯片还没工作就烧了&#xff1b;或者机器跑着跑着突然保护关机&#xff0c;拆开一看…

作者头像 李华