news 2026/4/17 13:10:25

集合的迭代器与遍历

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
集合的迭代器与遍历

Java集合迭代器与遍历:实现原理与性能优化

Java集合框架提供了多种迭代器和遍历方式,支持集合元素的顺序访问。为了深入理解集合的迭代和遍历过程,我们将从源码的角度详细分析迭代器的实现及其与遍历相关的操作。

1. 迭代器的基本概念

迭代器(Iterator)是用来遍历集合元素的对象,它提供了访问集合中元素的标准方式。通过迭代器,我们可以安全地从集合中提取元素,并且避免使用集合的索引或内部实现细节。Java中所有的集合类(如ListSet等)都可以通过Iterator接口提供迭代功能。

关键源码:Iterator接口

java复制

public interface Iterator<E> { boolean hasNext(); // 判断是否有下一个元素 E next(); // 获取下一个元素 void remove(); // 删除当前元素 }

2. 集合类中的迭代器实现

不同的集合类根据其内部数据结构,提供了不同的迭代器实现。以下是一些常见集合类的迭代器实现:

2.1ArrayList的迭代器实现

ArrayList使用数组作为底层数据结构,它的迭代器是通过内部类ArrayList$Itr实现的。

关键源码

java复制

public Iterator<E> iterator() { return new Itr(); } private class Itr implements Iterator<E> { int cursor; // 当前游标位置 int lastRet = -1; // 上一次返回的元素索引 int expectedModCount = modCount; // 期望的修改次数 public boolean hasNext() { return cursor != size; } public E next() { checkForComodification(); int i = cursor; if (i >= size) throw new NoSuchElementException(); Object[] elementData = ArrayList.this.elementData; if (i >= elementData.length) throw new ConcurrentModificationException(); cursor = i + 1; lastRet = i; return (E) elementData[lastRet]; } final void checkForComodification() { if (modCount != expectedModCount) throw new ConcurrentModificationException(); } }

2.2HashSet的迭代器实现

HashSet基于哈希表实现,其迭代器通过内部类HashSet$Iterator实现。与ArrayList类似,但哈希表的元素顺序是无序的。

关键源码

java复制

public Iterator<E> iterator() { return new Itr(); } private class Itr implements Iterator<E> { int expectedModCount; int nextIndex; Itr() { expectedModCount = modCount; nextIndex = 0; } public boolean hasNext() { return nextIndex < size; } public E next() { checkForComodification(); try { int i = nextIndex; E next = getEntry(i).element; nextIndex = i + 1; return next; } catch (IndexOutOfBoundsException e) { throw new NoSuchElementException(); } } final void checkForComodification() { if (modCount != expectedModCount) throw new ConcurrentModificationException(); } }

3. 迭代器的基本操作

Iterator接口中,主要有以下三个操作方法:

  • hasNext():判断是否有下一个元素。
  • next():获取下一个元素。
  • remove():删除当前元素。

通过这三个方法,用户可以遍历集合中的元素,并根据需要删除元素。例如,ArrayListItr内部类通过游标管理当前的元素位置,并支持元素的删除操作。

4. for-each循环与迭代器

Java中的增强for循环(即for-each循环)本质上是通过迭代器来实现的。每当我们使用for-each循环时,编译器会自动为我们创建一个Iterator对象,并调用Iteratornext()方法来逐一访问集合元素。

示例代码

java复制

for (E element : collection) { // 使用 element }
编译器转换

实际上,编译器会将上述代码转化为:

java复制

for (Iterator<E> it = collection.iterator(); it.hasNext(); ) { E element = it.next(); // 使用 element }

5. 迭代器的并发问题

在多线程环境中,迭代器可能面临并发问题。例如,在一个线程遍历集合时,另一个线程可能会修改集合的结构(增加、删除元素)。为了避免出现并发修改异常,Java集合框架提供了一些机制来处理并发情况。

关键源码:ConcurrentModificationException

当集合结构发生修改时,迭代器会检测到不一致,并抛出ConcurrentModificationException异常。以下是ArrayList中的modCount检测逻辑:

java复制

public final class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, Serializable { private transient int modCount = 0; // 记录集合修改次数 public Iterator<E> iterator() { return new Itr(); } private class Itr implements Iterator<E> { int expectedModCount = modCount; // 期望的modCount值 public E next() { if (modCount != expectedModCount) { throw new ConcurrentModificationException(); // 检测到结构修改 } // 其他逻辑 } } }

6. 集合的遍历方式

除了使用Iterator进行遍历外,Java提供了多种遍历集合的方式。常见的有:

  • 增强for循环:适用于所有实现了Iterable接口的集合类。
  • ListIteratorList接口提供了ListIterator,它不仅支持正向遍历,还支持反向遍历、修改元素等功能。

关键源码:ListIterator

java复制

public interface ListIterator<E> extends Iterator<E> { boolean hasPrevious(); // 判断是否有前一个元素 E previous(); // 获取前一个元素 void set(E e); // 设置当前元素 void add(E e); // 在当前元素前添加元素 }

7. 集合遍历的性能优化

在实际开发中,遍历集合时的性能也需要考虑。以下是一些优化建议:

  • ArrayList:使用Iterator遍历比直接使用索引访问更有效,因为每次访问索引都需要重新计算位置。
  • LinkedList:使用迭代器遍历的性能相对较好,因为它采用双向链表存储数据,可以更快地访问元素。
  • 大规模数据集合:避免在遍历过程中进行不必要的修改操作,并优先考虑使用高效的遍历方式,如并行流(parallelStream)来实现多线程遍历。

示例代码:并行流遍历

java复制

List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5); numbers.parallelStream().forEach(System.out::println);
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 21:56:43

Qwen3-1.7B temperature参数调优:生成质量提升实战指南

Qwen3-1.7B temperature参数调优&#xff1a;生成质量提升实战指南 你是不是也遇到过这样的情况&#xff1a;明明用的是最新开源的Qwen3-1.7B模型&#xff0c;输入同样的提示词&#xff0c;有时回答逻辑清晰、语言自然&#xff0c;有时却答非所问、啰嗦重复&#xff0c;甚至冒…

作者头像 李华
网站建设 2026/4/18 0:05:06

cv_unet_image-matting图像抠图实战教程:WebUI部署详细步骤

cv_unet_image-matting图像抠图实战教程&#xff1a;WebUI部署详细步骤 1. 为什么你需要这个抠图工具 你是不是经常遇到这些情况&#xff1a; 给客户做电商主图&#xff0c;要快速把人像从杂乱背景里抠出来&#xff0c;但PS太费时间&#xff1b;做社交媒体头像&#xff0c;想…

作者头像 李华
网站建设 2026/4/2 2:36:20

CAM++降本增效实战:中小企业声纹系统部署成本优化

CAM降本增效实战&#xff1a;中小企业声纹系统部署成本优化 1. 为什么中小企业需要“轻量级”声纹系统&#xff1f; 你有没有遇到过这些场景&#xff1a; 客服中心想做来电身份初筛&#xff0c;但商用声纹API按调用量收费&#xff0c;每月动辄上万元&#xff1b;员工考勤想加…

作者头像 李华
网站建设 2026/4/16 20:02:06

MinerU跨境电商应用:多语言说明书提取实战

MinerU跨境电商应用&#xff1a;多语言说明书提取实战 在跨境电商运营中&#xff0c;你是否经常遇到这样的问题&#xff1a;刚上架一批海外采购的电子设备&#xff0c;却只拿到一份全英文PDF说明书&#xff1b;平台要求补充德语、法语、日语版本&#xff0c;但人工翻译成本高、…

作者头像 李华
网站建设 2026/4/2 18:37:22

麦橘超然一键启动包:免配置快速部署完整指南

麦橘超然一键启动包&#xff1a;免配置快速部署完整指南 1. 这不是另一个“又要装环境”的AI工具 你是不是也经历过这样的时刻&#xff1a;看到一个惊艳的AI图像生成项目&#xff0c;兴致勃勃点开GitHub&#xff0c;结果第一行就写着“请先安装CUDA 12.1、PyTorch 2.3、DiffS…

作者头像 李华
网站建设 2026/4/17 22:04:23

ESP32实现离线语音识别大模型实战

以下是对您提供的博文内容进行 深度润色与工程化重构后的终稿 。整体风格更贴近一位资深嵌入式AI工程师在技术社区的真实分享&#xff1a;语言自然、逻辑严密、细节扎实&#xff0c;去除了所有AI生成痕迹和模板化表达&#xff1b;强化了“人话解释”、“踩坑经验”、“参数权…

作者头像 李华