java 迭代循环_Java迭代器(转)(iterator详解以及和for循环的区别)

迭代器是一种模式,它可以使得对于序列类型的数据结构的遍历行为与被遍历的对象分离,即我们无需关心该序列的底层结构是什么样子的。只要拿到这个对象,使用迭代器就可以遍历这个对象的内部.

1.Iterator

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

文档定义:

1 Package java.util;2 public interface Iterator{3 boolean hasNext();//判断是否存在下一个对象元素

4 E next();5 voidremove();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 importjava.util.Iterator;4 public interface Iterable{5 Iteratoriterator();6 }

使用Iterator的简单例子

1 import java.util.*;2

3 public class TestIterator {4

5 public static voidmain(String[] args) {6

7 List list=newArrayList();8

9 Map map=newHashMap();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 //循环map31 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 classTestIterator {3

4 public static voidmain(String[] args) {5

6 List list=new ArrayList();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无序,结构不同,他们的访问算法也不一样.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java中的迭代器Iterator)是一种对象,它可以遍历一个容器中的元素。迭代器模式是一种设计模式,可以将容器的遍历和实现分离。 Java中的迭代器Iterator)提供了一种方便的方法来遍历容器中的元素。它提供了三个基本操作: - hasNext(): 返回容器中是否还有下一个元素 - next(): 返回容器中的下一个元素 - remove(): 删除容器中最后一个被next()返回的元素 Java中的迭代器接口是Iterator,其中包含上述三个方法,实现类可以自定义实现这些方法以实现遍历。常见的容器类如List、Set都提供了迭代器的实现。使用迭代器可以更方便地遍历容器中的元素,并且可以在遍历过程中删除元素而不影响其他遍历操作。 ### 回答2: Java迭代器Iterator)是Java集合框架中一个非常重要的接口,用于遍历并访问集合中的元素。通过使用迭代器,我们可以避免使用传统的for循环方式遍历集合,从而使代码更加简洁、优雅和易于维护。 Java迭代器接口定义了一些常用的方法,使得我们可以在不管具体集合的实现细节的情况下,访问和处理集合中的元素。常用的方法包括: 1. hasNext(): 判断集合是否还有下一个元素。 2. next(): 返回集合中的下一个元素,并将迭代器指针向下一个元素移动。 3. remove(): 移除集合中的当前元素。 下面我们来看一个简单的例子,用来演示如何使用Java迭代器进行遍历: ``` ArrayList<String> list = new ArrayList<String>(); list.add("Java"); list.add("Python"); list.add("Ruby"); Iterator<String> it = list.iterator(); while (it.hasNext()) { String element = it.next(); System.out.println(element); } ``` 在上面的例子中,我们首先定义了一组字符串元素,并将它们添加到了一个ArrayList集合中。然后通过调用iterator()方法,得到了该集合的迭代器。接着,通过使用while循环和next()方法,逐个遍历集合中的元素,并将元素内容输出到控制台上。 需要注意的是,当调用next()方法,如果集合中已经没有更多的元素可供遍历了,则会抛出NoSuchElementException异常。因此,在使用Java迭代器,必须首先使用hasNext()方法来检查集合是否还有下一个元素可供遍历。 还需要注意的是,除了一些具体的集合类,如ArrayList,LinkedList, HashSet, TreeMap等,Java迭代器还可以用于自定义集合类。只要实现了Iterator接口,并在实现中定义next()、hasNext()、remove()三个方法即可。 总之,Java迭代器Java集合框架中一项非常重要的功能。通过使用迭代器,我们可以遍历和访问集合中的元素,避免了使用传统的for循环方式,从而使代码更加简洁、优雅和易于维护。 ### 回答3: Java中的迭代器Iterator)是一种用于遍历集合框架(Collection Framework)中元素的标准方式。Iterator返回的是一个迭代器对象,该对象允许程序员处理集合框架中储存的元素序列。 要使用Iterator遍历一个集合框架中的元素,需要按照以下步骤进行: 1. 调用集合框架中的iterator()方法,返回一个Iterator类型的对象; 2. 使用next()方法取出序列中的每一个元素,next()方法返回序列中的下一个元素,直到序列中的所有元素都被访问完; 3. 使用hasNext()方法判断序列中是否还有下一个元素,如果还有,则返回true,否则返回false。 另外,Iterator类型的对象只能单向遍历,即只能使用next()方法往后遍历,无法往前遍历。 Iterator除了提供基本的遍历操作外,还提供了一些额外的可选操作,例如: 1. remove()方法:从集合中移除迭代器返回的最后一个元素(如果支持的话); 2. forEachRemaining()方法:对集合中的每个元素执行指定的操作,直到所有元素都已被处理完毕或操作引发异常。 在使用Iterator,需要注意以下几个点: 1. 迭代器只能在对应的集合框架中进行遍历操作,否则会抛出ConcurrentModificationException异常; 2. 迭代器是单向的,一旦遍历到末尾,就无法回到开头; 3. 当集合中的元素被修改、插入或删除,遍历过程就会中断并抛出异常; 4. 迭代器虽然是fail-fast的,但这并不意味着它一定是线程安全的,如果多个线程同访问同一个集合,就需要进行加锁、同步等操作,否则可能会出现不可预期的结果。 总的来说,Iterator是一个十分重要的概念,是Java中集合框架遍历元素的标准方式。使用Iterator可以很方便地遍历集合中的元素,并且提供了一些可选操作,但在使用需要注意迭代器的特殊性质,以免出现异常情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值