1.集合的三种通用遍历方法

之前我们学习过集合的遍历方法,为什么这里还要再学呢?

这是因为,之前我们用的遍历方法使用了索引,但我们知道set接口的实现类的集合均无索引,所以我们要学习通用的遍历方法

2.迭代器遍历

1.迭代器

迭代器叫做Iterator,是一个接口,我们知道接口是不能直接实例化的

所以,我们通过集合调用iterator方法,以多态的形式创建迭代器对象

如下图,左边是迭代器,也就是接口,那么右边就必然是实现类对象

我们通过ArrayList点开源码,发现iterator方法new了一个itr对象,而itr实现了Iterator接口

2.迭代器遍历

1.next方法

Iterator接口里面有两个方法,其中next方法可以帮我们从集合中获取到元素

如图,集合中存在三个学生对象,我们调用一次next方法,就获取到了一个学生对象



.



.

那么,只要调用三次next,就可以将这三个学生对象全部获取到了

2.hasnext方法

为了获取到三个对象,就要调用三次next,假如有一万个对象,那也得调用next方法吗?实在麻烦

hasnext方法就可以解决这个问题

--hasnext方法用于判断集合中是否有元素可以获取,如果有就返回true,否则false

根据这个性质,我们就可以使用while循环搭配上hasnext和next来进行迭代器遍历,如图



.

3.迭代器遍历原理

了解java中的源代码,更便于我们理解迭代器,如下图

当我们通过iterator获取到迭代器后,就会产生Itr对象,即上面的代码

Itr对象里有一个cursor变量,该变量表示指针,也就是右边的箭头,指针会指向索引

又因为cursor是成员变量,所以默认值为0

接着进入while循环,走hasnext方法

根据上图可知,该方法判断集合中是否还有元素可以遍历是通过集合长度来判断的,当指针不等于集合的长度时,说明还有元素可以遍历

在这里,curosr=0,明显不等于size=4,while循环通过,走next方法

next方法中,声明了一个变量i,然后cursor给i赋值,用于记录上一次的cursor,接着cursor加1,指针指向1号索引,此时还没有获取到元素A!

elementData[]就是一个数组,[]里放的就是i,此时i=0,所以会获取到元素A,也就将元素A返回给我们了

由此可知,next方法底层原理是指针先移动,然后再将上一次的元素返回

走完next,回到while,接着走hasnext,此时cursor=1,不等于size,满足条件,再走next,以此类推.......

在循环的过程中,next方法最好只调用一次,否则会因为指针的移动而造成问题



.

.

4.增强for循环--本质迭代器

“:”右边写要遍历的集合,左边写接收获取到的元素的变量

快捷键:

5.foreach循环--本质迭代器

foreach循环里的参数consumer是一个函数式接口,所以要给实现类对象

使用匿名内部类重写后的方法,()里的参数就是集合里遍历的所有元素(stu)



.

因为是函数式接口,我们还可以用Lambda表达式

集合的通用遍历方法--java进阶day09的更多相关文章

  1. jQuery通用遍历方法each的实现

    each介绍 jQuery 的 each 方法,作为一个通用遍历方法,可用于遍历对象和数组. 语法为: jQuery.each(object, [callback]) 回调函数拥有两个参数:第一个为对 ...

  2. List集合三种遍历方法

    List<String> list = new ArrayList<String>();list.add("aaa");list.add("bbb ...

  3. Ruby 集合数组常用遍历方法

    迭代器简介 先简单介绍一下迭代器. 1.一个Ruby迭代器就是一个简单的能接收代码块的方法(比如each这个方法就是一个迭代器).特征:如果一个方法里包含了yield调用,那这个方法肯定是迭代器: 2 ...

  4. Map的遍历方法(java)

    方法一.Set<Object>  keySet();返回集合中所有的key组成的集合. 代码:Map<String , String > map=new HashMap();f ...

  5. Java遍历List集合的三种方法

    Java遍历List集合的三种方法 List<String> list = new ArrayList<String>(); list.add("aaa") ...

  6. Java遍历集合的几种方法分析(实现原理、算法性能、适用场合)

    概述 Java语言中,提供了一套数据集合框架,其中定义了一些诸如List.Set等抽象数据类型,每个抽象数据类型的各个具体实现,底层又采用了不同的实现方式,比如ArrayList和LinkedList ...

  7. Java遍历list集合的4种方法

    list集合的遍历4种方法: package com.sort; import java.util.ArrayList; import java.util.Iterator; import java. ...

  8. Java ——集合框架 list lambda set map 遍历方法 数据结构

    本节重点思维导图 集合框架 有序无序:元素放入的顺序与取出的顺序是否一致,一致即为有序,不一致即无序. List:允许重复.有序 ArrayList:长度可变的数组,遍历速度快 LinkedList: ...

  9. Java遍历集合的几种方法

    遍历集合的几种方法 用不同的方法遍历集合. public interface Iterator:对Collection进行迭代的迭代器.迭代器取代了Java Collections FrameWork ...

  10. java 遍历map 方法 集合 五种的方法

    package com.jackey.topic; import java.util.ArrayList;import java.util.HashMap;import java.util.Itera ...

随机推荐

  1. 【原创】浅谈EtherCAT主站EOE(下)-EtherCAT IgH主站EoE具体实现

    目录 1.IgH 框架概述 2. IgH EOE机制 2.1 EoE服务规范 2.1 EoE虚拟网络设备 2.1.1 EoE Virtual Network Interfaces 2.1.2 EoE ...

  2. BotSharp 4.0 Sidecar:迈向更大规模化的AI Agent平台框架

    BotSharp 是一个功能强大的开源项目,由 SciSharp[1] 社区开发和维护,旨在实现.NET技术栈下高度可定制的多智能体解决方案.为开发高效的对话式 AI 系统提供了极大的灵活性.通过其模 ...

  3. 修改leds-gpio.c 让GPIO LED在kernel启动时就开始闪烁

    内容提要: 客户需要在开机时就闪烁LED,并要求越快越好 diff --git a/drivers/leds/leds-gpio.c b/drivers/leds/leds-gpio.c index ...

  4. 记录以下uniapp写小程序然后进行图片上传压缩

    今天记录一下uniapp写小程序上传图片压缩的功能 首先定义上传图片的方法 然后res.tempFilePath[0]就是图片的临时路径 其次定义压缩图片然后获取压缩后图片大小的方法,方法使用canv ...

  5. 国家和地区代码列表,ISO 3166-1:2006

    本文根据ISO 3166-1:2006(International Standard Norme Internationale) 英文版(含2007年补充说明)整理.与ISO 3166-1:1997相 ...

  6. Maven详操作指南

    学习目标1. Maven 的环境搭建2. Pom.xml 文件的使用3. Maven 指令的使用4. Idea 创建 Maven 项目使用 Maven 改变传统项目构建为什么使用Maven,解决了哪些 ...

  7. Kotlin:【继承】:继承、函数重载、类型检测、as类型转换、智能类型转换、Kotlin层次

  8. cxGrid列的OnValidate事件处理程序

    procedure TForm1.cxGrid1DBTableView1AColumnPropertiesValidate(Sender: TObject; var DisplayValue: Var ...

  9. 问一下,利用在线 DeepSeek 等 API 服务实现一个答题 APP

    简介 这是一个利用 Android 无障碍功能 + 悬浮窗 + 大模型的搜题应用 原理就是利用无障碍读取屏幕内容,然后通过悬浮窗来显示答案 众所周知我是一个学渣,所以在搜答案方面颇有成就 大概是在 4 ...

  10. CF1896H2

    看不懂的题 首先考虑 \([a_i\neq b_i]=-2a_ib_i+a_i+b_i\),所以: \[f(a,b)=\sum a_i+\sum b_i-2\sum a_ib_i=N-2\sum a_ ...