迭代器
迭代器
迭代器
1.概述:
帮助我们做集合遍历的工具。
2.作用:
java中提供了很多种集合,它们在存储元素时,采用的存储方式不同。所以当我们要取出这些集合中的元素时,可以通过一种通用的获取方式来完成。
Collection集合元素的通用获取方式: 在取元素之前先要判断集合中有没有元素,如果有,就把这个元素取出来;继续再判断,如果还有就再取出来。一直到把集合中的所有元素全部取出。这种取出方式专业术语称为迭代。
集合中把这种取元素的方式描述在Iterator接口中。
3.Iterator接口的常用方法:
修饰语和类型 | 方法 | 描述 |
---|---|---|
boolean | hasNext() | 判断集合中还有没有可以被取出的元素,如果有返回true |
E | next() | 取出集合中的下一个元素 |
4.示例:
1 | public class IteratorDemo { |
输出为:
abc1
abc2
abc3
abc4
分析:
当Iterator<String> it = coll.iterator();
这段代码执行时,在集合内部就建立了一个指针(Java中没有指针概念,这里用指针来描述便于理解)。而指针的初识位置并不是指向内存中的0位,而是指向-1位。
每执行一次String s = it.next();
,该指针便移向下一个位。当指针移到最后一位后,它的下一位就没有元素了,也就是it.hasNext()
的返回值为false
时,结束遍历,跳出循环。并且一旦指针移到了最后一位,理论上便回不去了,所以说迭代器是一次性的。如果这时再调用String s = it.next();
,便会抛出空元素异常了。
5.迭代器的转型
由于集合是可以存储任意类型的对象的,所以就产生了转型的问题。
通过如下示例代码来分析:
1 | //集合可以存储任意类型的对象 |
上述示例代码中,由于元素被存放进集合后全部被提升为Object类型,当需要使用子类对象特有方法时,需要向下转型。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 FadeAway Space!
评论