news 2026/7/5 22:35:39

集合的迭代器与遍历

作者头像

张小明

前端开发工程师

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/7/3 0:45:40

思科修复已遭利用的 Unified CM RCE 0day漏洞

聚焦源代码安全&#xff0c;网罗国内外最新资讯&#xff01; 编译&#xff1a;代码卫士 思科已修复位于 Unified Communications 和 Webex Calling中一个严重的RCE漏洞CVE-2026-20045。该漏洞已遭利用。 该漏洞影响思科 Unified CM、Unified CM SME、Unified CM IM & Prese…

作者头像 李华
网站建设 2026/7/2 0:52:20

通义千问3-14B部署教程:Ollama+WebUI双Buff环境搭建步骤详解

通义千问3-14B部署教程&#xff1a;OllamaWebUI双Buff环境搭建步骤详解 1. 为什么选Qwen3-14B&#xff1f;单卡跑出30B级效果的“守门员” 你是不是也遇到过这些情况&#xff1a;想用大模型做长文档分析&#xff0c;但Qwen2-72B显存爆了&#xff1b;想上手开源模型&#xff0…

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

Qwen3-Embedding-4B缓存机制:响应速度提升实战优化

Qwen3-Embedding-4B缓存机制&#xff1a;响应速度提升实战优化 你有没有遇到过这样的情况&#xff1a;向量服务明明部署好了&#xff0c;但每次调用 embedding 接口都要等 800ms 以上&#xff1f;用户批量请求一上来&#xff0c;延迟直接飙到 1.5 秒&#xff0c;下游检索系统卡…

作者头像 李华
网站建设 2026/7/3 7:36:28

2025年AI语音情感分析趋势一文详解:Emotion2Vec+ Large落地指南

2025年AI语音情感分析趋势一文详解&#xff1a;Emotion2Vec Large落地指南 1. 为什么现在必须关注语音情感分析&#xff1f; 你有没有遇到过这样的场景&#xff1a;客服系统听懂了用户说的每一句话&#xff0c;却完全没察觉对方已经气得拍桌子&#xff1f;智能音箱准确复述了…

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

电商安防实战:用YOLOv10镜像实现人流检测应用

电商安防实战&#xff1a;用YOLOv10镜像实现人流检测应用 1. 为什么电商场景需要实时人流检测 你有没有注意过&#xff0c;商场入口处的电子屏上跳动的数字&#xff1f;那不是装饰&#xff0c;而是实时人流统计——它决定着导购排班、促销节奏甚至消防预案。传统红外计数器在…

作者头像 李华
网站建设 2026/6/25 16:45:08

对比传统双门限法,FSMN深度学习模型更精准

对比传统双门限法&#xff0c;FSMN深度学习模型更精准 语音端点检测&#xff08;Voice Activity Detection, VAD&#xff09;是语音处理流水线中看似简单却极其关键的第一步。它决定了后续语音识别、声纹分析、语音合成等任务的输入质量。一个不准的端点检测&#xff0c;就像给…

作者头像 李华