17.Iterator-迭代器模式

来源:互联网 发布:威科姆网络机顶盒 编辑:程序博客网 时间:2024/05/29 15:36

Iterator 迭代器模式

  • 迭代器模式:
    提供一种方法来访问聚合对象,而不用暴露这个对象的内部表示,其别名为游标(Cursor)。迭代器模式是一种对象行为型模式。
    迭代器模式就是顺序访问聚集中的对象,一般来说,集合中非常常见,如果对集合类比较熟悉的话,理解本模式会十分轻松。
    这句话包含两层意思:一是需要遍历的对象,即聚集对象,二是迭代器对象,用于对聚集对象进行遍历访问.

  • 示例类图:
    Iterator_uml

  • 示例代码:

public interface Iterator {    public boolean hasNext();    public Object next();}public interface Iterable {    public Iterator iterator();}public class NameContainer implements Iterable {    String names[] = { "Robert", "John", "Julie", "Tom" };    @Override    public Iterator iterator() {        return new NameIterator(this);    }}public class NameIterator implements Iterator {    private NameContainer nameContainer;    private int index;    public NameIterator(NameContainer nameContainer) {        this.nameContainer = nameContainer;    }    @Override    public boolean hasNext() {        if (index < nameContainer.names.length) {            return true;        }        return false;    }    @Override    public Object next() {        if (hasNext()) {            return nameContainer.names[index++];        }        return null;    }}// 测试public class IteratorTest {    public static void main(String[] args) {        Iterable iterable = new NameContainer();        Iterator iterator = iterable.iterator();        while (iterator.hasNext()) {            System.out.println(iterator.next());        }    }}
0 0
原创粉丝点击