迭代器模式

简介: 《大话设计模式》阅读笔记和总结。原书是C#编写的,本人用Java实现了一遍,包括每种设计模式的UML图实现和示例代码实现。目录:设计模式Github地址:DesignPattern定义:迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示。

《大话设计模式》阅读笔记和总结。原书是C#编写的,本人用Java实现了一遍,包括每种设计模式的UML图实现和示例代码实现。
目录:设计模式
Github地址:DesignPattern

定义:迭代器模式(Iterator),提供一种方法顺序访问一个聚合对象中各个元素,而又不暴露该对象的内部表示。

例子:乘坐公交车时,在一个站点上来了“大鸟、小菜、一个人的行李超重了,老外,公交内部员工、小偷这几个人“,用程序模仿公交车售票员卖票的过程。

UML图:

img_f399a7f7713cb72f771194e707b3f6ad.png
迭代器模式UML图.png

代码实现:

Iterator迭代器抽象类

public abstract class Iterator{
    public abstract Object First(); 
    public abstract Object Next(); 
    public abstract boolean IsDone(); 
    public abstract Object CurrentItem(); 
}

Agreegate聚集抽象类

public abstract class Aggregate {
    //创建迭代器
    public abstract Iterator CreateIterator();
}

ConcreteIterator 具体迭代器类,继承Iterator

public class ConcreteIterator extends Iterator{
    
    private ConcreteAggregate aggregate;
    private int current = 0;
    
    public ConcreteIterator(ConcreteAggregate aggregate) {
        this.aggregate = aggregate;
    }

    @Override
    public Object First() {
        return aggregate.getItems(0);
    }

    @Override
    public Object Next() {
        Object ret = null;
        current++;
        if (current < aggregate.count()) {
            ret = aggregate.getItems(current);
        }
        return ret;
    }

    @Override
    public boolean IsDone() {
        return current >= aggregate.count()? true : false;
    }

    @Override
    public Object CurrentItem() {
        // TODO Auto-generated method stub
        return aggregate.getItems(current);
    }

}

ConcreteAggregate 具体聚集类,继承Aggregate


public class ConcreteAggregate extends Aggregate{
    
    private List<Object> items = new ArrayList<>();
    
    @Override
    public Iterator CreateIterator() {
        // TODO Auto-generated method stub
        return new ConcreteIterator(this);
    }
  
    public int count() {
        return items.size();
    }

    public Object getItems(int index) {
        return items.get(index);
    }

    public void setItems(Object item) {
        items.add(item);
    }

}

客户端代码

public class Main {
    public static void main(String[] args) {
        //公交车,即聚集对象
        ConcreteAggregate a = new ConcreteAggregate();
        
        // 新上来的乘客,即对象数组
        a.setItems("大鸟");
        a.setItems("小菜");
        a.setItems("行李");
        a.setItems("老外");
        a.setItems("公司内部员工");
        a.setItems("小偷");
        
        //售票员出场,先看好上车都是哪些人
        Iterator i = new ConcreteIterator(a);
        Object item = i.First();
        while(!i.IsDone()){
            System.out.println(i.CurrentItem()+"请买车票!");
            //下一个乘客
            i.Next();
        }
    }
}

运行结果

大鸟请买车票!
小菜请买车票!
行李请买车票!
老外请买车票!
公司内部员工请买车票!
小偷请买车票!
目录
相关文章
|
2天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
253 116
|
17天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
11天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
650 220
|
存储 人工智能 监控
从代码生成到自主决策:打造一个Coding驱动的“自我编程”Agent
本文介绍了一种基于LLM的“自我编程”Agent系统,通过代码驱动实现复杂逻辑。该Agent以Python为执行引擎,结合Py4j实现Java与Python交互,支持多工具调用、记忆分层与上下文工程,具备感知、认知、表达、自我评估等能力模块,目标是打造可进化的“1.5线”智能助手。
886 61
|
9天前
|
人工智能 移动开发 自然语言处理
2025最新HTML静态网页制作工具推荐:10款免费在线生成器小白也能5分钟上手
晓猛团队精选2025年10款真正免费、无需编程的在线HTML建站工具,涵盖AI生成、拖拽编辑、设计稿转代码等多种类型,均支持浏览器直接使用、快速出图与文件导出,特别适合零基础用户快速搭建个人网站、落地页或企业官网。
1476 157
|
6天前
|
编解码 Linux 数据安全/隐私保护
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
282 139
|
8天前
|
存储 安全 固态存储
四款WIN PE工具,都可以实现U盘安装教程
Windows PE是基于NT内核的轻量系统,用于系统安装、分区管理及故障修复。本文推荐多款PE制作工具,支持U盘启动,兼容UEFI/Legacy模式,具备备份还原、驱动识别等功能,操作简便,适合新旧电脑维护使用。
594 109