Iterator集合迭代器

为什么Iterator迭代器定义的是接口,而不是一个类呢?

我们试想一下,如果Iterator迭代器是一个类。那么我们就可以直接创建一个迭代器,并且使用它的遍历方法了,这样是不是很方便? 但是呢,Java给我们提供了很多不同的集合类,然而这些不同的集合都有不同的数据结构。所以,它们的存储方式和遍历的方式也应该是不同的。最终,就没有定义迭代器的类了。

但是呢,无论是哪种集合,我们都应该具备相应的获取元素的功能(Iterator.next()),并且,最好配合一个辅助判断的功能方法(Iterator.hasNext()),这样的好处,在获取集合元素前都进行判断,是否有元素在集合中,更利于操作和更不容易出错。那么我们可以想,既然每个集合都有获取和判断的功能,那么我们就可以把功能方法抽取出来,但是呢并没有具体的实现。那么我们就称为接口。这也是为什么Iterator定义成了接口,而不是一个类的原因。

那么,真正的具体的实现类在哪里呢?
当然是在具体的子类中实现了,具体看源码:

 迭代器接口
public interface Iterator {   
boolean hasNext();
Object next();
 }

获取迭代器的接口
public interface Iterable {
    Iterator iterator();
}

Collection继承了获取迭代器接口的接口
public interface Collection extends Iterable { 
  Iterator iterator();  
}

 List接口,继承了Collection接口,并继承了获取迭代器的抽象方法
  public interface List extends Collection {
Iterator iterator();
 }

ArrayList具体的实现接口类,实现了获取Iterator的功能方法
public class ArrayList implements List { 
public Iterator iterator() {
    return new Itr();
  }


Itr是Iterator的具体实现类,在ArrayList以内部类的形式
 并且实现了Iterator的功能方法:hasNext(),next(),remove()
private class Itr implements Iterator {
    public boolean hasNext() {}       
    public Object next(){} 
    }
}

Collection c = new ArrayList();
c.add("hello");
c.add("world");
c.add("java");
Iterator it = c.iterator();  //实际是获取到了一个ArrayList的内部类new Itr();
while(it.hasNext()) {
String s = (String)it.next();
System.out.println(s);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 场景问题# 1.1 工资表数据的整合## 考虑这样一个实际应用:整合工资表数据。 这个项目的背景是这样的,项目...
    七寸知架构阅读 2,579评论 0 53
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,923评论 18 139
  • 1.Java集合框架是什么?说出一些集合框架的优点?每种编程语言中都有集合,最初的Java版本包含几种集合类:Ve...
    yjaal阅读 1,189评论 1 10
  • 很高兴又到了给好种子浇水施肥的时候了! 怀着喜悦和放松的心情回忆今天种下的好种子,虽然每天种下的都是一些微不足...
    绚风阅读 163评论 0 2
  • 微医集团招聘搜索研发工程师,坐标杭州,约吗? 职位诱惑: 五险一金、双休、国定节假日、年终奖、餐贴 职位描述: 任...
    刘邦杰阅读 172评论 0 1