数据结构(Java):迭代器遍历【底层源码解析】

news/2024/10/5 22:58:56/

1、引言

我们知道,对于List系列集合,添加的元素是有序、可重复、有索引的;而对于Set系列集合,添加的元素是无序、不重复、无索引的。

那么使用for循环通过下标来对Set系列集合进行遍历,那显然是不行的。

迭代器就可以解决这个问题。

因为迭代器迭代器不依赖索引,故既能对有索引集合进行遍历,又能对无索引集合进行遍历。

迭代器也是集合专用的遍历方式。

2、迭代器遍历

迭代器遍历的原理就是:从下标0的位置开始,一个元素一个元素的向后遍历,直到遍历结束。

注意:迭代器不依赖索引

代码如下:

java">public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();list.add("aaa");list.add("bbb");list.add("ccc");//获取迭代器对象Iterator<String> it = list.iterator();while (it.hasNext()) {//判断当前位置是否有元素String str = it.next();//1.获取当前位置 2.将迭代器指针指向下一个元素System.out.println(str);}}

我先对其中的方法做一下简单说明。

2.1 获取迭代器对象

使用迭代器进行遍历,我们首先需要获取迭代器对象,而我们可以调用ArrayList中的iterator方法来获取迭代器对象。

我们通过源码可以发现,返回值为Iterator<E>,我们使用Iterator<E>接收即可。

2.2 迭代器的方法

2.2.1 hasNext方法

该方法就是判断,当前迭代器对象指向的位置上是否有元素,若有元素,则返回true,若没有元素,则返回false。

2.2.2 next方法

该方法有两个步骤:

1.获取当前位置上的元素

2.迭代器指针往后移动,指向下一个元素


到目前为止,想要使用迭代器来进行遍历,以上的三种方法是我们必须要掌握的:

1.iterator方法:获取迭代器对象

2.hasNext方法:判断当前位置是否有元素

3.Next方法:获取当前位置元素并且迭代器指针向后移动


2.3 迭代器的四个细节

2.3.1 细节点1

如果当前位置没有元素,还使用next方法进行获取,会抛出NoSuchElementException异常

2.3.2 细节点2

迭代器遍历完毕,指针不会复位

2.3.3 细节点3

循环中只能用一次next方法

因为每使用一次next方法,指针就会向后移动一次;若循环中有两个next方法,而元素个数为奇数个时,则会一次循环指针移动两次,最后一次循环时,会有一个next获取元素时当前位置没有元素,会抛出NoSuchElementException异常。

2.3.4 细节点4

迭代器遍历时,不能使用集合的方法进行增加或删除元素

例如:

若在迭代器遍历时使用了集合的增加或者删除方法,会抛出ConcurrentModificationException(并发修改异常)

至于为什么不能使用集合的方法来修改元素,我将在下面的源码分析中解释。

所以,如果想要在迭代器遍历时修改元素,我们使用迭代器的相关方法即可:

代码:

java">public static void main(String[] args) {ArrayList<String> list = new ArrayList<>();list.add("aaa");list.add("bbb");list.add("ccc");Iterator<String> iterator = list.iterator();while (iterator.hasNext()) {String str = iterator.next();if ("aaa".equals(str)) {//迭代器遍历时,删除元素,只能使用迭代器的remove方法iterator.remove();}}System.out.println(list);}

如果要删除元素,使用迭代器的remove方法;

如果要添加元素,暂时还没有方法。


OK,迭代器遍历的大致内容已经阐述完毕,接下来是迭代器源码的深度解析


2.4 迭代器遍历 源码深度解析

我已经将底层源码分析整理在这张图上,清晰明了:

OK~本次博客到这里就结束了,

感谢大家的阅读~欢迎大家在评论区交流问题~

如果博客出现错误可以提在评论区~

创作不易,请大家多多支持~


http://www.ppmy.cn/news/1473705.html

相关文章

什么是 JVM( Java 虚拟机),它在 Java 程序执行中扮演什么角色?

JVM&#xff0c;全称Java Virtual Machine&#xff0c;中文译作“Java虚拟机”&#xff0c;它是运行Java程序的软件环境&#xff0c;也是Java语言的核心部分之一。 想象一下&#xff0c;如果你是一位环球旅行家&#xff0c;每到一个新的国家&#xff0c;都需要学习当地的语言才…

网络问题排查问题记录

一、问题描述 1.1 问题产生记录 准生产环境报出如下错误&#xff1a;连接某个服务器的时候出现连接超时现象&#xff1b;服务间调用是通过feignnacos实现的&#xff1b;服务部署是用k8s实现的&#xff1b;初步判断是A->B调用是服务端出了初五 二、问题定位 2.1 问题排查记录…

电脑为什么会提示丢失msvcp140.dll?怎么修复msvcp140.dll文件会靠谱点

电脑为什么会提示丢失msvcp140.dll&#xff1f;其实只要你的msvcp140.dll文件一损坏&#xff0c;然而你的电脑程序需要运用到这个msvcp140.dll文件的时候&#xff0c;就回提示你丢失了msvcp140.dll文件&#xff01;因为没有这个文件&#xff0c;你的很多程序都用不了的。今天我…

大数据中的常见数据问题:独断脏

想象你刚刚入职一家声称正在进行"数字化转型"的大型企业,担任大数据开发工程师。在入职的第一周,你满怀热情,迫不及待地想要大展拳脚,用你的技能来推动公司的数据驱动决策。 目录 大数据中的常见数据问题1. 独 - 数据孤岛2. 断 - 数据价值链断层3. 缺 - 标准、治理…

Codeforces Round 346 (Div. 2) E. New Reform 题解 并查集

New Reform 题目描述 Berland has n n n cities connected by m m m bidirectional roads. No road connects a city to itself, and each pair of cities is connected by no more than one road. It is not guaranteed that you can get from any city to any other one,…

【C语言小知识】缓冲区

缓冲区 当我们使用printf()将数据显示在屏幕上&#xff0c;或者使用scanf()函数将数据输入到电脑里&#xff0c;我们是否会产生些许疑问&#xff1f;为何输入的字符会直接显示到屏幕上等等。这里需要介绍一个C语言中的一个关键概念——缓冲区。 当我们使用老式系统进行运行代码…

机器人入门路线及参考资料(机器人操作方向)

机器人入门路线及参考资料&#xff08;机器人操作方向&#xff09; 前言1 数理基础和编程2 机器人学理论3 计算机视觉4 机器人实操5 专攻方向总结Reference: 前言 随着机器人和具身智能时代的到来&#xff0c;机器人越来越受到大家的重视&#xff0c;本文就介绍了机器人&#…

解决Python爬虫开发中的数据输出问题:确保正确生成CSV文件

引言 在大数据时代&#xff0c;爬虫技术成为获取和分析网络数据的重要工具。然而&#xff0c;许多开发者在使用Python编写爬虫时&#xff0c;常常遇到数据输出问题&#xff0c;尤其是在生成CSV文件时出错。本文将详细介绍如何解决这些问题&#xff0c;并提供使用代理IP和多线程…