美文网首页
Iterator集合迭代器

Iterator集合迭代器

作者: 帅气的猪猪 | 来源:发表于2016-09-10 13:55 被阅读59次

    为什么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);
    }

    相关文章

      网友评论

          本文标题:Iterator集合迭代器

          本文链接:https://www.haomeiwen.com/subject/cdmyettx.html