博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java面试知识点(二十六)迭代器iterator
阅读量:3783 次
发布时间:2019-05-22

本文共 1063 字,大约阅读时间需要 3 分钟。

迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构。迭代器通常被称为 “轻量级” 对象,因为创建它的代价小。

Java 中的 Iterator 功能比较简单,并且只能单向移动:

(1) 使用方法 iterator () 要求容器返回一个 Iterator。第一次调用 Iterator 的 next () 方法时,它返回序列的第一个元素。注意:iterator () 方法是 java.lang.Iterable 接口,被 Collection 继承。

(2) 使用 next () 获得序列中的下一个元素。

(3) 使用 hasNext () 检查序列中是否还有元素。

(4) 使用 remove () 将迭代器新返回的元素删除。

Iterator 是 Java 迭代器最简单的实现,为 List 设计的 ListIterator 具有更多的功能,它可以从两个方向遍历 List,也可以从 List 中插入和删除元素。

实例代码:

list 是一个 ArrayList 的对象,哪个选项的代码填到 //todo delete 处,可以在 Iterator 遍历的过程中正确并安全的删除一个 list 中保存的对象

Iterator it = list.iterator();int index = 0;while (it.hasNext()){
Object obj = it.next(); if (needDelete(obj)) //needDelete返回boolean,决定是否要删除 {
//todo delete } index ++;}

答案:it.remove();

注意不能选list.remove();

Iterator 支持从源集合中安全地删除对象,只需在 Iterator 上调用 remove() 即可。这样做的好处是可以避免 ConcurrentModifiedException(同时发生被改进异常) ,当打开 Iterator 迭代集合时,同时又在对集合进行修改。有些集合不允许在迭代时删除或添加元素,但是调用 Iterator 的 remove() 方法是个安全的做法。 因为它的 remove () 方法不仅会删除元素,还会维护一个标志,用来记录目前是不是可删除状态,例如,你不能连续两次调用它的 remove () 方法,调用之前至少有一次 next () 方法的调用。

转载地址:http://aslvn.baihongyu.com/

你可能感兴趣的文章
最大权闭合子图
查看>>
最小权点覆盖集 与 最大权独立集
查看>>
POJ 2125 Destroying The Graph && Acwing 2325. 有向图破坏(拆点+最小权点覆盖集)
查看>>
计算几何基础知识整理大全 代码模板与证明过程 (直线、向量、多边形、三维计算几何、凸包、半平面交、最小圆覆盖)
查看>>
计算几何之 判断两线段是否相交 代码模板与证明
查看>>
三维计算几何之三维凸包 增量法
查看>>
MySQL变量,存储过程,函数,流程控制详解(小白都能懂哦)
查看>>
9篇小白都能懂系列博客学完MySQL基础
查看>>
还在为Linux入门发愁?
查看>>
如何优雅而又不失内涵的在centos7下安装tree命令
查看>>
彻底掌握Linux文件与目录管理命令?进来看看硬核总结
查看>>
一文搞定Vim/Vi编辑器
查看>>
剑指offer之斐波那契问题(C++/Java双重实现)
查看>>
Linux网络命令
查看>>
一天教会三岁表弟HTML,你值得拥有
查看>>
CSS基础汇总
查看>>
SpringCloud服务注册与发现
查看>>
SpringCloud Stream 消息驱动
查看>>
SpringCloud Sleuth 分布式请求链路
查看>>
SpringCloud Alibaba Nacos 服务注册和配置中心
查看>>