>>分享Java编程技术,对《Java面向对象编程》等书籍提供技术支持 书籍支持  卫琴直播  品书摘要  在线测试  资源下载  联系我们
发表一个新主题 开启一个新投票 回复文章 您是本文章第 32196 个阅读者 刷新本主题
 * 贴子主题:  Java 迭代器Iterator用法详解(与for-each语句的区别) 回复文章 点赞(0)  收藏  
作者:flybird    发表时间:2019-05-17 21:53:12     消息  查看  搜索  好友  邮件  复制  引用

1.Iterator

Java提供一个专门的迭代器«interface»Iterator,我们可以对某个序列实现该interface,来提供标准的Java迭代器。Iterator接口实现后的功能是“使用”一个迭代器.

文档定义:

1 Package java.util;  
2 public interface Iterator<E> {
3   boolean hasNext();//判断是否存在下一个对象元素
4   E next();
5   void remove();
6 }


2.Iterable

Java中还提供了一个Iterable接口,Iterable接口实现后的功能是“返回”一个迭代器,我们常用的实现了该接口的子接口有: Collection, Deque, List, Queue, Set 等.该接口的iterator()方法返回一个标准的Iterator实现。实现这个接口允许对象成为 For each 语句的目标。就可以通过For each语法遍历你的底层序列。

Iterable接口包含一个能够产生Iterator的iterator()方法,并且Iterable接口被foreach用来在序列中移动。因此如果创建了任何实现Iterable接口的类,都可以将它用于foreach语句中。

文档定义:
1 Package java.lang;
2
3 import java.util.Iterator;
4 public  interface Iterable<T> {
5 Iterator<T> iterator();  
6 }

使用Iterator的简单例子
复制代码
1 import java.util.*;
2
3 public class TestIterator {
4
5 public  static void main(String[] args) {
6
7    List list=new ArrayList();
8
9    Map map=new HashMap();
10  //初始化list和map的数据
11   for(int i=0;i<10;i++){
12
13     list.add(new String("list"+i) );
14
15     map.put(i, new String("map"+i));
16
17   }
18
19 Iterator iterList= list.iterator();//List接口实现了Iterable接口
20   //循环list
21  while(iterList.hasNext()){
22
23    String strList=(String)iterList.next();  
24
25    System.out.println(strList.toString());  
26
27   }
28
29  Iterator iterMap=map.entrySet().iterator();
30   //循环map
31    while(iterMap.hasNext()){
32
33      Map.Entry strMap=(Map.Entry)iterMap.next();
34
35      System.out.println(strMap.getValue());  
36
37    }
38
39 }
40
41 }
复制代码
接口Iterator在不同的子接口中会根据情况进行功能的扩展,例如针对List的迭代器ListIterator,该迭代器只能用于各种List类的访问。ListIterator可以双向移动。添加了previous()等方法.



3 Iterator与泛型搭配

Iterator对集合类中的任何一个实现类,都可以返回这样一个Iterator对象。可以适用于任何一个类。

因为集合类(List和Set等)可以装入的对象的类型是不确定的,从集合中取出时都是Object类型,用时都需要进行强制转化,这样会很麻烦,用上泛型,就是提前告诉集合确定要装入集合的类型,这样就可以直接使用而不用显示类型转换.非常方便.



4.foreach和Iterator的关系

for each是jdk5.0新增加的一个循环结构,可以用来处理集合中的每个元素而不用考虑集合定下标。

格式如下

1 for(variable:collection){ statement; }


定义一个变量用于暂存集合中的每一个元素,并执行相应的语句(块)。collection必须是一个数组或者是一个实现了lterable接口的类对象。

上面的例子使用泛型和forEach的写法:  
复制代码
1 import java.util.*;
2 public  class TestIterator {
3
4 public  static void main(String[] args) {
5
6 List<String> list=new ArrayList<String> ();
7
8 for(int i=0;i<10;i++){
9   list.add(new String("list"+i) );
10 }
11
12 for(String str:list){
13   System.out.println(str);
14 }
15
16 }
复制代码


使用for循环时,在循环内使用list.remove()会导致错误,可以使用如下方法:

for(int i = 0; i < list.size();i++){
  if(true){
list.remove(list.get(i));
--i;//remove的同时下标跟着减
}
}
可以看出,使用for each循环语句的优势在于更加简洁,更不容易出错,不必关心下标的起始值和终止值。

forEach不是关键字,关键字还是for,语句是由iterator实现的,他们最大的不同之处就在于remove()方法上。

一般调用删除和添加方法都是具体集合的方法,例如:

List list = new ArrayList(); list.add(…); list.remove(…);

但是,如果在循环的过程中调用集合的remove()方法,就会导致循环出错,因为循环过程中list.size()的大小变化了,就导致了错误。 所以,如果想在循环语句中删除集合中的某个元素,就要用迭代器iterator的remove()方法,因为它的remove()方法不仅会删除元素,还会维护一个标志,用来记录目前是不是可删除状态,例如,你不能连续两次调用它的remove()方法,调用之前至少有一次next()方法的调用。

forEach就是为了让用iterator循环访问的形式简单,写起来更方便。当然功能不太全,所以但如有删除操作,还是要用它原来的形式。



4 使用for循环与使用迭代器iterator的对比

效率上的各有有事

采用ArrayList对随机访问比较快,而for循环中的get()方法,采用的即是随机访问的方法,因此在ArrayList里,for循环较快

采用LinkedList则是顺序访问比较快,iterator中的next()方法,采用的即是顺序访问的方法,因此在LinkedList里,使用iterator较快

从数据结构角度分析,for循环适合访问顺序结构,可以根据下标快速获取指定元素.而Iterator 适合访问链式结构,因为迭代器是通过next()和Pre()来定位的.可以访问没有顺序的集合.

而使用 Iterator 的好处在于可以使用相同方式去遍历集合中元素,而不用考虑集合类的内部实现(只要它实现了 java.lang.Iterable 接口),如果使用 Iterator 来遍历集合中元素,一旦不再使用 List 转而使用 Set 来组织数据,那遍历元素的代码不用做任何修改,如果使用 for 来遍历,那所有遍历此集合的算法都得做相应调整,因为List有序,Set无序,结构不同,他们的访问算法也不一样.


程序猿的技术大观园:www.javathinker.net
  Java面向对象编程-->输入与输出(下)
  JavaWeb开发-->集合(下)
  JSP与Hibernate开发-->Web运作原理(Ⅱ)
  Java网络编程-->JSP中使用JavaBean(Ⅰ)
  精通Spring-->
  Vue3开发-->数据库事务的概念和声明
  为网站代码块pre标签增加一个复制代码按钮代码
  详细介绍float和double类型的区别
   JAVA进阶之IO模型深入解析
  用注解去代替if-else的技巧
  购书咨询
  64匹马,8个赛道,找出跑得最快的4匹马
  Eclipse使用指南:快速修复功能
  Eclipse使用指南:创建Java项目的步骤
  Java设计模式:备忘录模式
  Java设计模式:装饰器模式
  Java入门实用代码:数组转集合
  Java 入门实用代码:取最大和最小值
  【Java 并发笔记】CountDownLatch 相关整理
  Eclipse中怎么一键去除java项目中的信息打印语句
  初学者该学哪种编程语言
  更多...
 IPIP: 已设置保密
楼主      
1页 0条记录 当前第1
发表一个新主题 开启一个新投票 回复文章


中文版权所有: JavaThinker技术网站 Copyright 2016-2026 沪ICP备16029593号-2
荟萃Java程序员智慧的结晶,分享交流Java前沿技术。  联系我们
如有技术文章涉及侵权,请与本站管理员联系。