【图解+源码】Java Iterator接口详解

本文通过实例解析了Java中的Iterator接口,介绍了其遍历集合、remove方法的工作原理,阐述了Iterable与Iterator的关系,并展示了使用forEachRemaining方法的遍历方式。
摘要由CSDN通过智能技术生成

如何理解Iterator

从最简单的用Iterator遍历ArrayList的一段程序开始

List<String> list = new ArrayList<String>();
list.add("a");                              
list.add("b");                              
list.add("c");                              
list.add("d");                              
                                            
Iterator iterator = list.iterator();        
while(iterator.hasNext()){
                     
    System.out.print(iterator.next() + “\t”);    
}                                           

打印结果:
a b c d

上面的程序通过调用ArrayList对象list的iterator()方法获取了一个迭代器iterator,通过iterator的hasNext()方法和next()方法配合完成对list的遍历。
这种遍历方式与传统的按下标遍历是不太一样的

以上面的程序为例,当还未开始进行遍历时,迭代器的位置与list元素位置关系如下,iterator站在了首元素前面
在这里插入图片描述
开始遍历时,先调用hasNext()判断下一个要遍历的位置是否超过最后一个位置d,如果不超过,则调用next(),next()干了两件事情:

  1. 再次判断iterator的下一个位置是否超过d,超过的话则抛异常

  2. iterator向前走一步,走到a和b之间的位置:
    在这里插入图片描述

  3. 返回iterator的前一个位置,也就是a

这是遍历的第一步,接下来的每一步也是要走这样的流程。

所以,我们可以想象成,iterator处于两个元素之间的位置,每次遍历时,要用hasNext()先判断后面还有没有元素,有的话,则通过next()前进一步并返回上一个经过的元素

Iterator的remove方法

从一段错误的程序开始

 List<String> list = new ArrayList<String>(); 
 list.add("a");                               
 list.add("b");                               
 list.add("c");                               
 list.add("d");                               
                                              
 Iterator iterator = list.iterator()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值