Java中迭代器Iterator的使用

Java集合类中Map接口下的相关类并没有像Collection接口的相关类一样实现get()方法,因此在要实现遍历输出的场景中没法直接用get()方法来取得对象中的数据,但Java本身提供了另一种遍历数据的方法,即用Iterator迭代器,虽然Iterator可以用来遍历读取数据,但它本质上不是一种方法,它只是一种设计模式,它是一个对象,一个“轻量级”的对象。下文讲讲Iterator在不同接口中的使用方法:

(一)Iterator在Collection接口中的使用。

   虽然Collection接口的相关类实现了get()方法,但将Iterator用在它们身上仍然是合适的,下面以ArrayList为例,讨论Iterator在Collection中的两中使用方法:

 1.配合while()循环实现遍历输出:

  

1 ArrayList list = new ArrayList();
2 //此处省略list的具体赋值过程
3 Iterator it = list.iterator();
4         while(it.hasNext()){
5             System.out.println(it.next());
6         }

while()中的判断条件it.hasNext()用于判断it中是否还有下一元素,有的话就继续循环,输出语句中的it.next()既可以使“指针”往后走一位,又能将当前的元素返回,用于输出。

 2.配合for()循环实现遍历输出:

1 ArrayList list = new ArrayList();
2 //此处省略list的赋值过程
3 for(Iterator it = list.iterator();it.hasNext();){
4             System.out.println(it.next());
5 }

for()循环中的使用原理跟while()是一样的,在此就不再过多赘述。

不过上面的是在一般for()循环中的使用,我们还可以将之与for each 循环来代替Iterator,因为for each 本身就相当于一个迭代器了:

1 ArrayList list = new ArrayList();
2 //此处同样省略list的赋值过程
3 for(Object array:list){
4            System.out.println(array);
5 }

需要注意的是for each 不适合用来增删元素,如果单纯用来遍历元素,这种写法也许会更简洁一点。

(二)Iterator在Map接口中的使用:

下文用HashMap为例,讨论迭代器的两种主要使用方法。

1.与while()的结合

1 HashMap<K,V> myMap = new HashMap<K,V>();
2 //省略myMap的的赋值过程
3 Iterator<Map.Entry<K,V> it=myMap.entrySet().iterator();
4 while(it.hasNext()){
5         System.out.println(it.next());
6 }
7
8 //如果想让输出更加格式化,可以自己重写toString()方法,由于toString方法的重写不是本文讨论的重点,所以暂且不讨论。

Map接口下的iterator应用方法与Collection中的略微有些不同,用到了entrySet()方法,entrySet()用来返回整个键—值对。

2.与for()的结合

1 HashMap<K,V> myMap=new HashMap<K,V>();
2 //省略myMap的赋值过程
3 for(Iterator<Map.Entry<K,V>> it=myMap.entrySet().iterator();it.hasNext();){
4             System.out.println(it.next());
5 }

有上面几个例子的说明,这里就不用继续解释原理了。

同样这里再贴出for each代替Iterator的用法:

1 HashMap<K,V> myMap=new HashMap<K,V>();
2 //省略myMap赋值过程
3 for(Object oj:myMap.entrySet()){
4             System.out.println(oj);
5 }

for each 中同样要用到entrySet()方法,具体如果对entrySet方法有疑问,请自行百度,本文不过多描述。

结语:由于Iterator类封装在java.util路径下,所以要使用Iterator需先import java.util.Iterator;或者import java.util.*;

本人其实也只是初学者,有出错的地方欢迎指正。

时间: 2024-10-29 08:06:07

Java中迭代器Iterator的使用的相关文章

Java中迭代器

任何容器类,都必须有某种方法可以插入元素并将它们再次取回,毕竟,持有事物是容器最基本的工作,对于List,add()是出入元素的方法之一,而get()是取出元素的方法之一. 如果从更高层的角度思考,会发现这里有个缺点:要使用容器,必须对容器的确切类型编程, [要操作List,你就必须知道操作的是List,那么必须提供对List的操作方法,该方法即对List进行编程]初看起来这没什么不好,但是考虑到下面的情况:如果原本是对着List编码的,但是后来发现如果能够把相同的代码应用到Set,将会显得非常

java中的Iterator和Iterable

1.Iterable接口在java.lang包中:Iterator接口在java.util包中 2.Iterable中只有一个方法,那就是返回一个Iterator迭代器:Iterator<T> iterator() 而Iterator中有关于迭代器的核心功能,next(),hasNext(),remove() 所以说,Iterable接口实现后的功能是“返回”一个迭代器,而Iterator接口实现后的功能是“使用”一个迭代器 3.在java.util中的容器类基本都实现了Iterable ,下

Java中的Iterator用法

迭代器定义: 迭代器是一种设计模式,它是一个对象.迭代器模式(Iterator Pattern)是 Java 和 .Net 编程环境中非常常用的设计模式,迭代器模式属于行为型模式.这种模式用于顺序访问集合对象的元素,不需要知道集合对象的底层表示. 迭代器功能:Java中的Iterator功能简单,并且只能单向移动遍历 (1)iterator()方法:容器使用iterator()返回一个Iterator. 注意:iterator()方法是java.lang.Iterable接口,被Collecti

java中的Iterator接口

Iterator接口 Iterator接口也是Java集合框架的成员,但它与Collection系列.Map系列的集合不一样:Collection系列集合.Map系列集合主要用于盛装其他对象,而Iterator则主要用于遍历(即迭代访问)Collection集合中的元素,Iterator对象也被称为迭代器. Iterator接口里定义了如下4个方法: –boolean hasNext():如果被迭代的集合还元素没有被遍历,则返回true. –Object next():返回集合里下一个元素. –

Java 实现迭代器(Iterator)模式

类图 /** * 自定义集合接口, 类似java.util.Collection * 用于数据存储 * @author stone * */ public interface ICollection<T> { IIterator<T> iterator(); //返回迭代器 void add(T t); T get(int index); } /** * 自定义迭代器接口 类似于java.util.Iterator * 用于遍历集合类ICollection的数据 * @author

java中的iterator迭代器

Collection的iterator方法返回一个实现了一个Iterator接口的对象 Iterator接口中包含三个方法: 1)E next() 2)boolean hasNext() 3)void remove 具体用法: Iterator<Integer> integers=collection.iterator(); while(integers.hasNext()){ System.out.print(integers.next()+" "); } 可以通过调用h

Java中迭代器初深

今天学习了迭代器,老师对迭代器的两个方法hasNext()和Next(),做了深入的理解,并且举了一个简单的例子大致模拟了底层的实现,下面我来记录下实现的过程,首先建立了一个 Collection.java 这是模拟的Collection接口 代码如下: package cn.itcast.studyIterator; public interface Collection {    public Object get(int index);    public int size();    p

STL中迭代器 (Iterator) 的简单实现

#pragma once struct InputIteratorTag {}; struct OutputIteratorTag {}; struct ForwardIteratorTag : public InputIteratorTag {}; struct BidirectionalIteratorTag : public ForwardIteratorTag {}; struct RandomAccessIteratorTag : public BidirectionalIterato

java中的Iterator与增强for循环的效率比较

最近在优化代码时遇到了这个问题:Iterator与增强for循环到底哪个效率高?之前在学习的时候,好像记着老师说过遍历集合(如list)时,使用iterator好像正规一些,因为是专用的,但是运行效率问题确实不曾考虑,今天做了一个实验:对两者进行了简单的比较,得出的结论是:增强for循环运行效率更高一些.但是我不确定这是否会代表全部情况,这里仅仅记录一下,做个参考,后期有新的认识再来补充,欢迎大家批评指正. 1 public static void main(String[] args) { 2