【JAVA】Java中集合的遍历

简介: 在实际开发中,经常需要按照某种次序对集合中的每个元素进行访问,并且仅访问一次,这种对集合的访问也称为集合的遍历。针对这种需求,JDK 提供了Iterator 接口 和 foreach 循环 。本次将对Iterator 接口和foreach 循环遍历集合进行讲解。

51ff383aaec743ddbd12e5383c73148a.jpg


🏆今日学习目标:集合遍历

😃创作者:颜颜yan_

✨个人主页:颜颜yan_的个人主页

⏰本期期数:第五期

🎉专栏系列:JAVA


前言


在实际开发中,经常需要按照某种次序对集合中的每个元素进行访问,并且仅访问一次,这种对集合的访问也称为集合的遍历。针对这种需求,JDK 提供了Iterator 接口 foreach 循环 。本次将对Iterator 接口和foreach 循环遍历集合进行讲解。


一、Iterator接口


Iterator 接口是 Java 集合框架中的一员,但它与 Collection 接口和 Map 接口有所不同,Collection 接口和 Map 接口主要用于存储元素,而 Iterator 接口主要用于迭代访问(遍历)集合中的元素,通常情况Iterator 对象也被称为迭代器。


下面通过一个案例介绍如何使用Iterator 接口遍历集合中的元素,代码如下所示:


import  java.util.*;
public class Main {
    public static void main(String[] args) {
        ArrayList list = new ArrayList<>();   //创建集合
        list.add("张三");             //向集合中添加元素
        list.add("李四");
        list.add("王五");
        list.add("马六");
        Iterator it = list.iterator(); //获取Iterator对象
        while (it.hasNext()){           //判断集合中是否存在下一个元素
            Object obj = it.next();         //取出集合中的元素
            System.out.println(obj);
        }
    }
}


上述代码 演示的是使用Iterator 遍历集合的整个过程。代码第四行创建了Array List 集合 list,并调用add()方法添加了4 个元素。第9行代码通过调用 ArrayList 的iterato()方法获得了一个迭代器对象。10~13 行代码使用迭代器对象 计遍历集合。首先使用 hasNext方法判断集合中是否存在下一个元素。如果集合中存在下一个元素,则调用 next()方法将元素取出;否则说明己到达集合末尾,停止遍历元素。在调用 next()方法获取元素时,必须保证要获取的元素存在;否则,程序会抛出无此元素异常。


运行结果如图:


69b2d46d33e841a3929f7bc661662e8f.png


Iterator 对象在遍历集合时,内部采用指针的方式来跟踪集合中的元素。Iterator 遍历集合中的元素的过程如下图所示。在图中,在调用 Iterator 的 next()方法之前,Iterator 的指针位于第一个元素之前,不指向任何元素;第一次调用 Iterator 的 next()方法时,Iterator 的指针会向后移动一位,指向第一个元素并将该元素返回;当第二次调用 next()方法时,Iterator 的指针会指向第三个元素并将该元素返回;以此类推,直到 hasNext()方法返回false,表示己经遍历完集合中所有的兀素,终止对元素的遍历。


4cce4400ecaa45fe84503e5c07df2328.png


需要注意的是,通过 Iterator 获取集合中的元素时,这些元素的类型都是 Object 类型如果想获取特定类型的元素。则需要对数据类型进行强制转换


二、foreach循环


虽然 Iterator 可以用来遍历集合中的元素,但在写法上比较烦琐。为了简化书写,从JDK 5 开始,JDK 提供了 foreach 循环,它是一种更加简洁的for 循环,主要用于遍历数组或集合中的元素语法格式如下


for(容器中元素类型 临时变量:容器变量){
  执行语句
}


由上述foreach 值环语法格式可知,与for循环相比foreach 循环不需要获得集合的长度,也不需要根据索引访问集合中的元素,就能够自动遍历集合中的元素。通过一个案例来演示foreach循环的方法,代码如下:


import  java.util.*;
public class Main {
    public static void main(String[] args) {
        ArrayList list = new ArrayList<>();   //创建集合
        list.add("张三");             //向集合中添加元素
        list.add("李四");
        list.add("王五");
        list.add("马六");
        list.add("赵七");
        for (Object obj:
                list) {                //使用foreach循环遍历集合
            System.out.println(obj);    //取出并打印集合中的元素
        }
    }
}


在上述代码中,声明了一个ArrayList集合,并且向集合中添加了五个元素,最后用foreach运行遍历集合并打印。


运行结果如图所示:


f58b462ede654dacae34642bbba8c190.png


foreach 循环在遍历集合时语法非常简洁,没有储环条件,也没有迭代语句,所有这些工作都交给 Java 虚拟机执行了。


foreach 循环的次数是由集合中元素的个数决定的,每次循环时,foreach 都通过临时变量将当前福环的元素记住,从而将集合中的元素分别打印出来。


总结


本次介绍了两种遍历集合的方法,可以通过Iterator接口来遍历集合并打印,也可以用foreach来遍历打印,相对来说,foreach比较简洁。


以上就是今天的学习内容啦~


如果有兴趣的话可以订阅专栏,持续更新呢~


咱们下期再见~


da56ebb70343461c9eb214e0aef26e35.gif

目录
相关文章
|
3天前
|
存储 安全 算法
【常见集合】Java 常见集合重点解析
【常见集合】Java 常见集合重点解析
8 0
|
3天前
|
Java
Tree Traversals Again(Java语言)(先序和中序创建二叉树)(遍历树)
Tree Traversals Again(Java语言)(先序和中序创建二叉树)(遍历树)
12 4
|
3天前
|
算法 Java
【Java高阶数据结构】图-图的表示与遍历(下)
【Java高阶数据结构】图-图的表示与遍历
13 1
|
1天前
|
存储 Java 容器
Java一分钟之-高级集合框架:LinkedList与TreeSet
【5月更文挑战第17天】这篇博客对比了Java集合框架中的LinkedList和TreeSet。LinkedList是双向链表,适合中间插入删除,但遍历效率低且占用空间大;TreeSet基于红黑树,保证元素有序且不重复,插入删除速度较LinkedList慢但查找快。选择时需根据操作需求和性能考虑。
10 2
|
2天前
|
存储 算法 Java
Java 集合框架
5月更文挑战第10天
|
3天前
|
机器学习/深度学习 存储 Java
【Java高阶数据结构】图-图的表示与遍历(上)
【Java高阶数据结构】图-图的表示与遍历
10 2
|
3天前
|
Java 数据库
JAVA8遍历tree
JAVA8遍历tree
|
3天前
|
存储 安全 Java
Java一分钟之-集合框架进阶:Set接口与HashSet
【5月更文挑战第10天】本文介绍了Java集合框架中的`Set`接口和`HashSet`类。`Set`接口继承自`Collection`,特征是不允许重复元素,顺序不确定。`HashSet`是`Set`的实现,基于哈希表,提供快速添加、删除和查找操作,但无序且非线程安全。文章讨论了`HashSet`的特性、常见问题(如元素比较规则、非唯一性和线程安全性)以及如何避免这些问题,并提供了代码示例展示基本操作和自定义对象的使用。理解这些概念和注意事项能提升代码效率和可维护性。
12 0