Iterator迭代器接口介绍(集合容器遍历)

2020-11-18 0 By admin

Iterator对象称为迭代器(设计模式的一种),主要用于遍历Collection 集合中的元素。
GOF给迭代器模式的定义为:提供一种方法访问一个容器(container)对象中各个元素,而又不需暴露该对象的内部细节。迭代器模式,就是为容器而生。类似于“公交车上的售票员”、“火车上的乘务员”、“空姐”。

一、使用 Iterator 遍历集合容器

Iterator 仅用于遍历集合,Iterator本身并不提供承装对象的能力,如果需要创建Iterator 对象,则必须有一个被迭代的集合。
Collection 接口继承了 java.lang.Iterable 接口,该接口有一个iterator()方法,那么所有实现了Collection接口的集合类都有一个iterator()方法。

iterator() 方法用以返回一个实现了Iterator接口的对象。
集合对象每次调用iterator()方法都得到一个全新的迭代器对象,默认游标都在集合的第一个元素之前。

  1. Iterator内部的方法hasNext(),检查集合中是否还有下一个元素。
  2. Iterator内部的方法next(),指针下移,将下移以后集合位置上的元素返回
  3. 内部定义了remove(),可以在遍历的时候,删除集合中的元素。此方法不同于集合直接调用remove()。

1.1、Iterator 遍历集合示例

public void test(){
  Collection coll = new ArrayList();
  coll.add(123);
  coll.add(456);
  coll.add(new Person("Jerry",20));
  coll.add(new String("Tom"));
  coll.add(false);
  Iterator iterator = coll.iterator(); //获取迭代器对象

//遍历集合方式一;不推荐
  System.out.println(iterator.next());
  System.out.println(iterator.next());
  System.out.println(iterator.next());
  System.out.println(iterator.next());
  System.out.println(iterator.next());
  //报异常:NoSuchElementException
  //在调用it.next()方法之前必须要调用it.hasNext()进行检测。若不调用,且下一条记录无效,直接调用it.next()会抛出NoSuchElementException异常。
  System.out.println(iterator.next());

//方式二:不推荐
  for(int i = 0;i < coll.size();i++){
   System.out.println(iterator.next());
  }

//方式三:推荐
  while(iterator.hasNext()){
   System.out.println(iterator.next());
  }
		
		
//错误方式一:
  Iterator iterator = coll.iterator();
  while(iterator.next() != null){
   System.out.println(iterator.next());
  }

//错误方式二:
  //集合对象每次调用iterator()方法都得到一个全新的迭代器对象,默认游标都在集合的第一个元素之前。
  while(coll.iterator().hasNext()){
   System.out.println(coll.iterator().next());
  }
}

1.2、迭代器Iterator的执行原理

迭代器执行原理
迭代器执行原理

二、新特性foreach循环遍历集合或数组

Java 5.0 提供了foreach循环迭代访问 Collection 和数组。
遍历操作不需获取Collection或数组的长度,无需使用索引访问元素。遍历集合的底层调用Iterator完成操作。