随笔- 79  文章- 1  评论- 1  阅读- 1678 

概述

迭代器模式 (Iterator Pattern) 又称游标 (Cursor)。它提供了一种方式访问聚合对象中的元素而不用暴露这个对象的内部表示。

优点:符合“单一职责原则”、“开闭原则”。
缺点:增加系统复杂度。

interface Iterator {
  void first();
  void next();
  boolean hasNext();
  Object currentItem();
}

interface Aggregate {
  Iterator createIterator();
}

class Sub1Aggregate implements Aggregate {
  private Object[] obj = {};
  
  public Iterator createIterator() {
    return new Sub1Iterator();
  }
  
  private class Sub1Iterator implements Iterator {
    private int curr = 0;
   
    public void first() {
      curr = 0;
    }

    public void next() {
      if (curr < obj.length) {
        curr++;
      }
    }

    public boolean hasNext() {
      return curr != obj.length;
    }

    public Object currentItem() {
      return obj[curr];
    }
  }
}

图示:
image

参考

[1] 刘伟, 设计模式. 2011.

 posted on   x-yun  阅读(7)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
点击右上角即可分享
微信分享提示