Iterator 与 ListIterator:Java 集合框架中的遍历器比较

news2024/9/21 22:36:11

Iterator 与 ListIterator:Java 集合框架中的遍历器比较

  • 1、Iterator
    • 1.1 特点
  • 2、ListIterator
    • 2.1 特点
  • 3、Iterator 和 ListIterator 的区别
  • 4、示例
    • 4.1 使用 Iterator 遍历 Set
    • 4.2 使用 ListIterator 遍历 List 并修改
  • 5、总结


💖The Begin💖点点关注,收藏不迷路💖

在Java的集合框架中,遍历集合元素通常有两种主要的遍历器:IteratorListIterator。尽管它们都是用于遍历集合的工具,但它们在功能和使用上存在一些关键的区别。

1、Iterator

Iterator 是Java集合框架中的一个核心接口,它允许我们遍历(即逐个访问)集合中的元素,而无需了解集合底层的实现细节。Iterator 接口的主要方法是:

  • hasNext():判断是否存在下一个元素。
  • next():返回集合中的下一个元素,并将迭代器的游标向前移动一位。
  • remove()(可选):删除迭代器最后返回的元素。

1.1 特点

  • 适用于任何实现了 Collection 接口的集合,包括 SetList
  • 只能进行前向遍历。
  • 不提供直接访问元素索引的方法。
  • 不允许在遍历过程中修改集合的结构(除了通过 remove() 方法删除当前元素外)。

2、ListIterator

ListIteratorIterator 的子接口,专为 List 集合设计。它除了继承 Iterator 的功能外,还提供了更多的操作来遍历和修改 List

ListIterator 接口的主要方法包括(除了 Iterator 的方法外):

  • hasPrevious():判断是否存在上一个元素。
  • previous():返回集合中的上一个元素,并将迭代器的游标向后移动一位。
  • add(E e):将元素插入到列表中,紧跟在迭代器的当前位置之前。
  • set(E e):用指定的元素替换通过 next()previous() 返回的最后一个元素。
  • nextIndex()previousIndex():分别返回对 next()previous() 的下一个调用的索引。

2.1 特点

  • 专用于 List 集合的遍历和修改。
  • 既可以前向遍历也可以后向遍历。
  • 允许在遍历过程中添加、替换和删除元素。
  • 提供直接访问元素索引的方法。

3、Iterator 和 ListIterator 的区别

  1. 适用范围

    • Iterator:适用于任何实现了 Collection 接口的集合。
    • ListIterator:专为 List 集合设计,只能用于遍历和修改 List
  2. 遍历方向

    • Iterator:只能前向遍历。
    • ListIterator:既可以前向遍历也可以后向遍历。
  3. 修改功能

    • Iterator:仅提供了删除当前元素的功能。
    • ListIterator:提供了添加、替换和删除元素的功能。
  4. 索引访问

    • Iterator:不提供直接访问元素索引的方法。
    • ListIterator:提供了直接访问元素索引的方法。

4、示例

4.1 使用 Iterator 遍历 Set

Set<String> set = new HashSet<>();  
set.add("A");  
set.add("B");  
set.add("C");  
  
Iterator<String> iterator = set.iterator();  
while (iterator.hasNext()) {  
    String element = iterator.next();  
    System.out.println(element);  
}

4.2 使用 ListIterator 遍历 List 并修改

List<String> list = new ArrayList<>();  
list.add("A");  
list.add("B");  
list.add("C");  
  
ListIterator<String> listIterator = list.iterator();  
while (listIterator.hasNext()) {  
    String element = listIterator.next();  
    System.out.println(element);  
      
    // 假设我们想要替换第一个元素  
    if (listIterator.nextIndex() == 1) {  
        listIterator.set("X"); // 将 "B" 替换为 "X"  
    }  
}  
  
// 打印修改后的列表  
for (String s : list) {  
    System.out.println(s); // 输出: A X C  
}

5、总结

Iterator 和 ListIterator 都是在Java集合框架中用于遍历集合的重要工具。选择哪一个取决于你的具体需求:

1、如果你只需要遍历集合,并且不关心元素的索引或修改集合,那么 Iterator 就足够了;

2、如果你需要遍历 List 集合,并且希望在遍历过程中添加、替换或删除元素,那么 ListIterator 是更好的选择。
在这里插入图片描述


💖The End💖点点关注,收藏不迷路💖

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1933088.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《昇思25天学习打卡营第24天| 文本解码原理》

文本解码原理--以MindNLP为例 回顾&#xff1a;自回归语言模型 根据前文预测下一个单词 一个文本序列的概率分布可以分解为每个词基于其上文的条件概率的乘积 &#x1d44a;_0:初始上下文单词序列&#x1d447;: 时间步当生成EOS标签时&#xff0c;停止生成。 MindNLP/huggi…

SpringBoot框架学习笔记(二):容器功能相关注解详解

1 Spring 注入组件的注解 Component、Controller、 Service、Repository这些在 Spring 中的传统注解仍然有效&#xff0c;通过这些注解可以给容器注入组件 2 Configuration 2.1 应用实例 需求说明: 演示在 SpringBoot, 如何通过Configuration 创建配置类来注入组件 回顾…

少儿编程启蒙宝典:Scratch动画游戏108变

一、编程教育的时代价值与意义 随着数字时代的深入发展&#xff0c;社会对人才的需求正发生深刻变革&#xff0c;计算思维与编程能力已成为衡量个人竞争力的重要指标。在此背景下&#xff0c;培养孩子们运用计算思维解决实际问题的能力&#xff0c;成为教育领域的重要任务。编…

【PPT笔记】1-3节 | 默认设置/快捷键/合并形状

文章目录 说明笔记1 默认设置1.1 OFFICE版本选择1.1.1 Office某某数字专属系列1.1.2 Office3651.1.3 产品信息怎么看 1.2 默认设置1.2.1 暗夜模式1.2.2 无限撤回1.2.3 自动保存&#xff08;Office2013版本及以上&#xff09;1.2.4 图片压缩1.2.5 字体嵌入1.2.6 多格式导出1.2.7…

C++ | Leetcode C++题解之第235题二叉搜索树的最近公共祖先

题目&#xff1a; 题解&#xff1a; class Solution { public:TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {TreeNode* ancestor root;while (true) {if (p->val < ancestor->val && q->val < ancestor->val) {anc…

音视频开发入门教程(2)配置FFmpeg编译 ~共210节

在上一篇博客介绍了安装&#xff0c;音视频开发入门教程&#xff08;1&#xff09;如何安装FFmpeg&#xff1f;共210节-CSDN博客 感兴趣的小伙伴&#xff0c;可以继续跟着老铁&#xff0c;一起开始音视频剪辑功能&#xff0c;&#x1f604;首先查看一下自己的电脑是几核的&…

《昇思25天学习打卡营第20天|GAN图像生成》

生成对抗网络&#xff08;GAN&#xff09;是一种深度学习模型&#xff0c;用于生成逼真的图像。在手写数字识别的任务中&#xff0c;GAN 可以用来生成与真实手写数字相似的图像&#xff0c;以增强模型的训练数据集。GAN 主要由两个部分组成&#xff1a;生成器&#xff08;Gener…

httpx 的使用

httpx 是一个可以支持 HTTP/2.0 的库 还有一个是&#xff1a; hyper 库 这里有一个由HTTP/2.0的网站&#xff1a; https://spa16.scrape.center/ 使用 requests 库 进行爬取 import requests url https://spa16.scrape.center/ response requests.get(url) print(response…

Lua基础知识入门

1 基础知识 标识符&#xff1a;标识符的定义和 C语言相同&#xff1a;字母和下划线_ 开头&#xff0c; 下划线_ 大写字母一般是lua保留字&#xff0c; 如_VERSION 全局变量&#xff1a;默认情况下&#xff0c;变量总是认为是全局的&#xff0c;不需要申明&#xff0c;给一个变…

28_EfficientNetV2网络详解

V1&#xff1a;https://blog.csdn.net/qq_51605551/article/details/140487051?spm1001.2014.3001.5502 1.1 简介 EfficientNetV2是Google研究人员Mingxing Tan和Quoc V. Le等人在2021年提出的一种深度学习模型&#xff0c;它是EfficientNet系列的最新迭代&#xff0c;旨在提…

golang单元测试性能测试常见用法

关于go test的一些说明 golang安装后可以使用go test工具进行单元测试 代码片段对比的性能测试,使用起来还是比较方便,下面是一些应用场景 平时自己想做一些简单函数的单元测试&#xff0c;不用每次都新建一个main.go 然后go run main.go相对某个功能做下性能测试 看下cpu/内存…

Anthropic推出1亿美元AI基金,加剧与OpenAI的竞争|TodayAI

人工智能初创公司Anthropic和风险投资公司Menlo Ventures宣布&#xff0c;他们将共同推出一支价值1亿美元的基金&#xff0c;以支持早期初创公司并推动它们使用Anthropic的技术。这个名为Anthology Fund的新基金&#xff0c;将为初创公司提供资金和技术支持&#xff0c;旨在模仿…

三、GPIO口

我们在刚接触C语言时&#xff0c;写的第一个程序必定是hello world&#xff0c;其他的编程语言也是这样类似的代码是告诉我们进入了编程的世界&#xff0c;在单片机中也不例外&#xff0c;不过我们的传统就是点亮第一个LED灯&#xff0c;点亮电阻&#xff0c;电容的兄弟&#x…

锁策略和CAS指令

锁策略 一、锁策略的引入二、锁策略的分类&#xff08;1&#xff09;乐观锁和悲观锁&#xff08;2&#xff09;重量级锁和轻量级锁&#xff08;3&#xff09; 自旋锁和挂起等待锁&#xff08;4&#xff09;可重入锁和不可重入锁&#xff08;5&#xff09;公平锁和非公平锁&…

SQL面试题练习 —— 统计最大连续登录天数区间

目录 1 题目2 建表语句3 题解 1 题目 2 建表语句 CREATE TABLE IF NOT EXISTS user_login_tb (uid INT,login_date DATE ); insert into user_login_tb(uid, login_date) values( 1, 2022-08-02),(1, 2022-08-03),(2, 2022-08-03),(2, 2022-08-04),(2, 2022-08-05),(2, 2022-08…

使用Python的Turtle模块绘制小黄人

引言 在Python编程的世界里&#xff0c;turtle 模块是一个非常有趣且实用的工具&#xff0c;它允许程序员通过简单的指令控制一个虚拟的画笔&#xff08;称为“海龟”&#xff09;在屏幕上移动和绘制图形。本篇博客将详细介绍如何使用turtle模块来绘制一个卡通人物&#xff0c…

Redis-布隆过滤器(Bloom Filter)详解

文章目录 什么是布隆过滤器 布隆过滤器的优点&#xff1a;布隆过滤器的缺点&#xff1a;其他问题 布隆过滤器适合的场景布隆过滤器原理 数据结构增加元素查询元素删除元素 如何使用布隆过滤器 Google开源的Guava自带布隆过滤器Redis实现布隆过滤器 Redis中配置布隆过滤器Redis…

给Wordpress添加评分功能到评论表单

今天要 给你的 Wordpress 添加评分功能到评论表单 吗&#xff1f; 评分功能效果图 什么类型的网站需要评分&#xff1f; 资源站教程站其他&#xff0c;我也没想到。。。 但我这个网站&#xff0c;因为是电影类的网站&#xff0c;好像还是有点需要的&#xff0c;所以&#xf…

完美的用户体验:如何设计一个直观和有效的网站导航?

APP的顶部导航栏对我们来说很熟悉。导航栏是UI设计中不可或缺的一部分&#xff0c;几乎每个页面都使用导航栏。虽然导航栏看起来很简单&#xff0c;不需要太多精力&#xff0c;但是设计一个与产品需求和客户目标高度匹配的导航栏并不是那么容易的。导航栏的设计标准有很多细节需…

SpringBoot集成MQTT实现交互服务通信

引言 本文是springboot集成mqtt的一个实战案例。 gitee代码库地址&#xff1a;源码地址 一、什么是MQTT MQTT&#xff08;Message Queuing Telemetry Transport&#xff0c;消息队列遥测传输协议&#xff09;&#xff0c;是一种基于发布/订阅&#xff08;publish/subscribe&…