网站首页 > 技术文章 正文
1 Iterator的概念
在Java中,如果我们需要遍历一个集合(Collection)或者数组(Array),我们通常会使用for循环来遍历。但是,当我们需要在遍历的过程中修改集合或者数组时,这种方式就不再适用了。因为在遍历的时候,我们不能同时修改同一个集合或者数组,否则会抛出ConcurrentModificationException异常。因此,Java提供了一种迭代器(Iterator)来解决这个问题。
Java Iterator(迭代器)不是一个集合,它是一种用于访问集合的方法,可用于迭代 ArrayList 和 HashSet 等集合。
Iterator 是 Java 迭代器最简单的实现,ListIterator 是 Collection API 中的接口, 它扩展了 Iterator 接口。
2 Iterator的定义
迭代器是一个对象,允许用户每次获得和使用集合中的一个元素,它与某个集合一同使用,但是它是一个单独的对象。迭代器是有助于实现某个集合的一种机制。
在java中,迭代器提供了一种标准方法,可以一次访问集合中的每一个元素,这是一种通用的操作。迭代器是一个对象,允许用户每次获取和使用集合中的一个元素。JavaAPI中迭代器由两个基本的接口实现的:
Iterator:用于定义一个对象,该对象作为一个迭代器。
Iterable:用于定义一个集合,从该集合中可以抽取出一个迭代器。
集合定义为Iterable,当需要的时候可以提供一个Iterator对象。Iterable接口只有一个方法,名字为 iterator() 返回值是一个Iterator对象,当创建一个集合时需要确定元素的类型,通常是在迭代器中定义元素:
public Iterator iterator() {
return new ArrayListIterator();
}
Iterator接口含有3个方法。前两个是hasNext和next,可以用于依次访问集合中的元素。
大多数的迭代器都是fail-fast的,当迭代器使用之中,如果要修改集合将抛出一个异常。
许多时候我们含显示迭代器的while,而不是使用for-each循环。因为,首先是一般不需要迭代的所有元素,另外,如果使用remove,需要调用显示的迭代器,然而foreach没有提供对迭代器的显示访问。
3 Iterator的使用
获取一个迭代器:集合想获取一个迭代器可以使用 iterator() 方法。
// 引入 ArrayList 和 Iterator 类
import java.util.ArrayList;
import java.util.Iterator;
public class RunoobTest {
public static void main(String[] args) {
// 创建集合
ArrayList<String> sites = new ArrayList<String>();
sites.add("Google");
sites.add("Runoob");
sites.add("Taobao");
sites.add("Zhihu");
// 获取迭代器
Iterator<String> it = sites.iterator();
// 输出集合中的第一个元素
System.out.println(it.next());
}
}
// 执行以上代码,输出结果如下:
// Google
循环集合元素:让迭代器 it(迭代器名字) 逐个返回集合中所有元素最简单的方法是使用 while 循环。
// 引入 ArrayList 和 Iterator 类
import java.util.ArrayList;
import java.util.Iterator;
public class RunoobTest {
public static void main(String[] args) {
// 创建集合
ArrayList<String> sites = new ArrayList<String>();
sites.add("Google");
sites.add("Runoob");
sites.add("Taobao");
sites.add("Zhihu");
// 获取迭代器
Iterator<String> it = sites.iterator();
// 输出集合中的所有元素
while(it.hasNext()) {
System.out.println(it.next());
}
}
}
// 执行以上代码,输出结果如下:
// Google
// Runoob
// Taobao
// Zhihu
删除元素:删除集合中的元素可以使用 remove() 方法。
// 引入 ArrayList 和 Iterator 类
import java.util.ArrayList;
import java.util.Iterator;
// 以下实例我们删除集合中小于 10 的元素
public class RunoobTest {
public static void main(String[] args) {
ArrayList<Integer> numbers = new ArrayList<Integer>();
numbers.add(12);
numbers.add(8);
numbers.add(2);
numbers.add(23);
Iterator<Integer> it = numbers.iterator();
while(it.hasNext()) {
Integer i = it.next();
if(i < 10) {
it.remove(); // 删除小于 10 的元素
}
}
System.out.println(numbers);
}
}
// 执行以上代码,输出结果如下:
// [12, 23]
注意:Java 迭代器是一种单向遍历机制,即只能从前往后遍历集合中的元素,不能往回遍历。同时,在使用迭代器遍历集合时,不能直接修改集合中的元素,而是需要使用迭代器的 remove() 方法来删除当前元素。
4 为什么选择Iterator?
- 抽象化遍历:Iterator将遍历集合的逻辑抽象化,使得用户无需关心集合的具体实现细节,即可实现遍历操作。这种抽象化提高了代码的复用性和可维护性。
- 安全性:在遍历集合时,直接对集合进行修改(如添加或删除元素)可能会导致ConcurrentModificationException异常。而Iterator提供的remove()方法则允许在遍历过程中安全地删除元素,避免了这种异常的发生。
- 灵活性:Iterator接口可以被不同的集合类实现,包括List、Set等,使得不同类型的集合都能以统一的方式被遍历。此外,通过自定义Iterator实现,还可以为特定需求提供特殊的遍历逻辑。
- 遵循设计模式:Iterator模式是一种行为型设计模式,它提供了一种方法来顺序访问一个集合对象中的各个元素,而又不暴露该对象的内部表示。这种设计模式在Java集合框架中得到了广泛的应用。
尽管Iterator提供了强大的遍历功能,但它也有一些局限性。例如,Iterator只能单向遍历集合,不能反向遍历或随机访问集合中的元素。此外,Iterator的remove()方法只能删除最近通过next()方法访问的元素,这在一定程度上限制了删除操作的灵活性。
- 上一篇: 深入理解SPI机制 spi 机制
- 下一篇: 半小时搞懂 IO 模型 io模型详解
猜你喜欢
- 2024-12-18 Java开发中MongoDB数据库相关操作
- 2024-12-18 HashMap有几种遍历方法?推荐使用哪种?
- 2024-12-18 在RedisTemplate中使用scan代替keys指令
- 2024-12-18 MQ的发布订阅模式(fanout) mq几种消息模式
- 2024-12-18 Mybatis参数-ParameterMapping处理参数
- 2024-12-18 既然有MySQL了,为什么还要有MongoDB?
- 2024-12-18 Java遍历一个 List 有哪些方式?每种的实现原理以及哪种最高效?
- 2024-12-18 为什么很多人不愿意用hibernate了?
- 2024-12-18 Qt中 QMap 类、QHash 类、QVector 类详解
- 2024-12-18 半小时搞懂 IO 模型 io模型详解
- 1507℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 511℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 487℃MySQL service启动脚本浅析(r12笔记第59天)
- 467℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 465℃启用MySQL查询缓存(mysql8.0查询缓存)
- 445℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 424℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 421℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)