【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

相关文章
|
6天前
|
Java 容器
java集合框架复习----(1)
这篇文章提供了Java集合框架的复习资料,包括集合的概念、Collection接口的使用,以及如何通过代码示例演示集合的操作,如增加、删除元素,以及遍历集合元素。
java集合框架复习----(1)
|
5天前
|
存储 Java
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
|
6天前
|
存储 安全 Java
java集合框架复习----(2)List
这篇文章是关于Java集合框架中List集合的详细复习,包括List的特点、常用方法、迭代器的使用,以及ArrayList、Vector和LinkedList三种实现类的比较和泛型在Java中的使用示例。
java集合框架复习----(2)List
|
6天前
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set
|
6天前
|
存储 Java
java集合框架复习----(3)Set
这篇文章详细介绍了Java集合框架中的Set集合,包括HashSet和TreeSet的特点、实现原理和使用示例,展示了Set集合的无序性、元素唯一性以及如何通过自定义比较器实现元素的排序。
|
6天前
|
存储 安全 Java
java集合框架学习笔记
这篇文章是关于Java集合框架的详细学习笔记,包括集合的概念、使用方式以及List、Set和Map等集合类型的具体实现和特点。
java集合框架学习笔记
|
11天前
|
安全 算法 Java
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)(下)
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)
50 6
|
11天前
|
存储 安全 Java
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)(中)
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)
52 5
|
11天前
|
存储 安全 Java
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)(上)
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)
44 3
|
11天前
|
存储 算法 Java
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
LeetCode经典算法题:二叉树遍历(递归遍历+迭代遍历+层序遍历)以及线索二叉树java详解
30 0