顾名思义,迭代器模式就是顺序访问汇集中的对象,通常来讲,集合中很是常见,若是对集合类比较熟悉的话,理解本模式会十分轻松。这句话包含两层意思:一是须要遍历的对象,即汇集对象,二是迭代器对象,用于对汇集对象进行遍历访问。咱们看下关系图:java
这个思路和咱们经常使用的如出一辙,MyCollection中定义了集合的一些操做,MyIterator中定义了一系列迭代操做,且持有Collection实例,咱们来看看实现代码:设计模式
两个接口:框架
public interface Collection { public Iterator iterator(); /*取得集合元素*/ public Object get(int i); /*取得集合大小*/ public int size(); }
public interface Iterator { //前移 public Object previous(); //后移 public Object next(); public boolean hasNext(); //取得第一个元素 public Object first(); }
两个实现:ide
public class MyCollection implements Collection { public String string[] = {"A","B","C","D","E"}; @Override public Iterator iterator() { return new MyIterator(this); } @Override public Object get(int i) { return string[i]; } @Override public int size() { return string.length; } }
public class MyIterator implements Iterator { private Collection collection; private int pos = -1; public MyIterator(Collection collection){ this.collection = collection; } @Override public Object previous() { if(pos > 0){ pos--; } return collection.get(pos); } @Override public Object next() { if(pos<collection.size()-1){ pos++; } return collection.get(pos); } @Override public boolean hasNext() { if(pos<collection.size()-1){ return true; }else{ return false; } } @Override public Object first() { pos = 0; return collection.get(pos); } }
测试类:测试
public class Test { public static void main(String[] args) { Collection collection = new MyCollection(); Iterator it = collection.iterator(); while(it.hasNext()){ System.out.println(it.next()); } } }
输出:A B C D E优化
此处咱们貌似模拟了一个集合类的过程,感受是否是很爽?其实JDK中各个类也都是这些基本的东西,加一些设计模式,再加一些优化放到一块儿的,只要咱们把这些东西学会了,掌握好了,咱们也能够写出本身的集合类,甚至框架!this