概念:
迭代器模式:Provide a way to access the elements of an aggregarte object sequentiaally with exposing its underlying representation. 提供一種訪問容器對象內每個元素的一種方式,并且不暴露對象的一些內部細節。
實現:
迭代器接口定義
public interface Iterator {Object next();Boolean hasNext(); }
容器接口定義
public interface Box {void add(Object object);Iterator createIterator(); }
迭代器實現
public class BoxIterator implements Iterator {private BookBox bookBox;private Integer size;private Integer index;public BoxIterator(BookBox bookBox){this.bookBox = bookBox;this.size = bookBox.size();this.index = 0;}@Overridepublic Object next() {if(index<size){return bookBox.getElement(index++);}return null;}@Overridepublic Boolean hasNext() {return index<size;} }
容器實現
public class BookBox implements Box {private Vector vector = new Vector();@Overridepublic void add(Object object) {this.vector.add(object);}public Object getElement(Integer index){if(index<vector.size()){return vector.get(index);}return null;}public Integer size(){return vector.size();}@Overridepublic Iterator createIterator() {return new BoxIterator(this);} }
測試及結果:
@Test public void iteratorTest() {BookBox bookBox = new BookBox();bookBox.add("歷史書");bookBox.add("政治書");bookBox.add("語文書");bookBox.add("數學書");bookBox.add("英語書");Iterator iterator = bookBox.createIterator();while (iterator.hasNext()) {System.out.println(iterator.next());} }
歷史書
政治書
語文書
數學書
英語書
分析:
1.簡化了對容器的遍歷操作,直接提供了遍歷接口
2.最常用的就是jdk的集合迭代器,這個迭代器接口是在1.2版本加入的。