迭代器
1、Iterator<E>集合 接口 JDK 1.2
在程序开发中,经常需要遍历集合中的所有元素。针对这种需求,JDK专门提供了一个接口java.util.Iterator
。Iterator
接口也是Java集合的一员,但它与Collection
、Map
接口不同,该两集合主要用于存储元素,而Iterator
主要用于迭代访问(遍历)Collection
中的元素,因此Iterator
对象也被称之为迭代器。
想要遍历Collection集合,那么就要获取该集合迭代器完成迭代操作:
public Iterator iterator()
:获取集合对应的迭代器,用来遍历集合中的元素。
迭代:即Collection集合元素的通用获取方式。在取元素之前要判断集合中有没有元素,如果有,就把这个元素取出来,继续在判断,如果还有就再取出来。直到所有元素被取出。这种方法专业术语成为迭代。
由于Collection抽象类,没有提供下标,要遍历元素,就得使用Iterator迭代器来遍历。
常用方法
public boolean hasNext()
:迭代中是否还有下一个元素public E next()
:返回迭代中的下一个元素
public class TestIterator{
public static void main(String[] args){
Collection<String> coll = new ArrayList<>();
coll.add("A");
coll.add("B");
coll.add("C");
// 通过while循环迭代获取元素
Iterator<String> iterator = coll.iterator(); // 实列化迭代器,指针指向 -1
while(iterator.hasNext()){
System.out.println(iterator.next());
}
// 通过for循环迭代获取元素 hasNext()判断之后指针会自动下移
for(Iterator<String> it = coll.iterator(); it.hasNext();){
System.out.println(iterator.next());
}
}
}
2、Enumeration<E> 集合 接口 JDK 1.0
枚举迭代与Iterator迭代类似,这是JDK1.0遍历Vector集合的接口。
注意:该接口的功能由Iterator接口复制。 此外,Iterator还添加了一个可选的删除操作,并具有较短的方法名称。 新的实现应该考虑使用迭代器优先于枚举。
JDK1.2以上基本不用该接口来遍历获取元素了。
常用方法
boolean hasMoreElements()
:测试该枚举是否包含更多元素E nextElement()
:如果此枚举对象至少有一个要提供的元素,则返回此枚举的下一个元素。