Java中迭代器的使用

Java中迭代器的使用

迭代器

1.概述:

帮助我们做集合遍历的工具。

2.作用:
java中提供了很多种集合,它们在存储元素时,采用的存储方式不同。所以当我们要取出这些集合中的元素时,可以通过一种通用的获取方式来完成。

Collection集合元素的通用获取方式: 在取元素之前先要判断集合中有没有元素,如果有,就把这个元素取出来;继续再判断,如果还有就再取出来。一直到把集合中的所有元素全部取出。这种取出方式专业术语称为迭代。

集合中把这种取元素的方式描述在Iterator接口中。

3.Iterator接口的常用方法:

修饰语和类型 方法 描述
boolean hasNext() 判断集合中还有没有可以被取出的元素,如果有返回true
E next() 取出集合中的下一个元素

4.示例:

public class IteratorDemo {
   
	public static void main(String[] args) {
   
		Collection<String> coll = new ArrayList<String>();	//多态
		coll.add("abc1");
		coll.add("abc2");
		coll.add("abc3");
		coll.add("abc4");
		// 迭代器,对集合ArrayList中的元素进行取出
		// 调用集合的方法iterator()获取Iterator接口的实现类的对象
		Iterator<String> it = coll.iterator();
		// 接口实现类对象,调用方法hasNext()判断集合中是否有元素
		// boolean b = it.hasNext();
		// System.out.println(b);
		// 接口的实现类对象,调用方法next()取出集合中的元素
		// String s = it.next();
		// System.out.println(s);

		// 迭代是反复内容,使用循环实现,循环的终止条件:集合中没元素, hasNext()返回了false
		while (it.hasNext()) {
   
			String s = it.next();
			System.out.println(s);
		}
	}
}

输出为:

abc1
abc2
abc3
abc4

分析:
Iterator<String> it = coll.iterator();这段代码执行时,在集合内部就建立了一个指针(Java中没有指针概念,这里用指针来描述便于理解)。而指针的初识位置并不是指向内存中的0位,而是指向-1位。
在这里插入图片描述
每执行一次String s = it.next();,该指针便移向下一个位。当指针移到最后一位后,它的下一位就没有元素了,也就是it.hasNext()的返回值为false时,结束遍历,跳出循环。并且一旦指针移到了最后一位,理论上便回不去了,所以说迭代器是一次性的。如果这时再调用String s = it.next();,便会抛出空元素异常了。

5.迭代器的转型

由于集合是可以存储任意类型的对象的,所以就产生了转型的问题。

通过如下示例代码来分析:

//集合可以存储任意类型的对象
//当集合中不用泛型指定存储的数据类型时,集合什么都存。
Collection coll = new ArrayList();
coll.add("abc");
coll.add("def");
coll.add("opq");
//获取迭代器
Iterator it = coll.iterator();
while (it.hasNext()) {
   
	// it.next()获取出来的对象数据类型为Object
	//Object obj = it.next();
	//当需要使用子类对象特有方法时,需要向下转型
	String str = (String) it.next();
 	System.out.println(str.length());
}

//注意:如果集合中存放的是多种对象,这时进行向下转型会发生类型转换异常。

上述示例代码中,由于元素被存放进集合后全部被提升为Object类型,当需要使用子类对象特有方法时,需要向下转型。

本文来源MrKorbin,由架构君转载发布,观点不代表Java架构师必看的立场,转载请标明来源出处:https://javajgs.com/archives/25324

发表评论