设计模式:生活中的迭代器模式

这篇具有很好参考价值的文章主要介绍了设计模式:生活中的迭代器模式。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

迭代器模式可以通过日常生活中的餐厅菜单遍历来类比。想象一下,你走进一家餐厅,服务员给了你一本菜单。这本菜单就像是一个聚合对象,它包含了各种菜品。你可以一页一页地翻阅菜单,这个翻阅的过程就像是使用迭代器来遍历聚合对象的元素。

生活场景类比

在这个类比中,菜单提供了一个统一的接口来遍历菜品,你不需要知道菜单是如何内部组织的,你只关心如何从头到尾查看菜单。这个过程就是迭代器模式的核心:提供一种方法来顺序访问聚合对象中的元素,而不暴露其内部的结构。

  • 菜单(聚合对象):餐厅提供的菜单,包含了一系列菜品。
  • 服务员(客户端代码):服务员提供给你菜单,并可能向你推荐某些菜品。
  • 你(迭代器用户):顾客使用菜单,一页一页地查看,决定点什么菜。
  • 翻页(迭代器的操作):你翻阅菜单的动作,对应迭代器的 next() 操作。
  • 是否到菜单末尾的判断(迭代器的终止条件):你检查是否翻到了菜单的最后一页,对应迭代器的 hasNext() 方法。

代码

如果我们把这个类比转换成代码,那么可以这样来实现:

// 迭代器接口
interface Iterator<T> {
    boolean hasNext();
    T next();
}

// 菜单项
class MenuItem {
    private String name;
    private double price;

    public MenuItem(String name, double price) {
        this.name = name;
        this.price = price;
    }

    // Getter and setter methods...
}

// 菜单聚合接口
interface Menu {
    Iterator<MenuItem> createIterator();
}

// 具体的菜单类
class DinnerMenu implements Menu {
    private List<MenuItem> menuItems;

    public DinnerMenu() {
        menuItems = new ArrayList<>();
        // 添加一些菜品到菜单
        addItem("Vegetarian BLT", 2.99);
        addItem("BLT", 2.99);
        addItem("Soup of the day", 3.29);
        // 更多菜品...
    }

    public void addItem(String name, double price) {
        MenuItem menuItem = new MenuItem(name, price);
        menuItems.add(menuItem);
    }

    @Override
    public Iterator<MenuItem> createIterator() {
        return menuItems.iterator(); // 利用 Java 内置的迭代器
    }
}

// 客户端代码
public class MenuTestDrive {
    public static void main(String[] args) {
        Menu dinnerMenu = new DinnerMenu();
        Iterator<MenuItem> iterator = dinnerMenu.createIterator();

        while (iterator.hasNext()) {
            MenuItem item = iterator.next();
            System.out.println(item.getName() + ", $" + item.getPrice());
        }
    }
}

总结

通过餐厅菜单的类比,我们可以更深入地理解迭代器模式:

  • 隐藏复杂性:正如你不需要知道菜单是如何打印和组织的,迭代器模式隐藏了聚合对象的内部结构。
  • 统一接口:翻阅菜单的方式对所有餐厅都是一样的,迭代器模式提供了一个统一的接口来遍历不同的聚合结构。
  • 支持多种遍历:就像不同的菜单可能有不同的遍历方式(比如按菜系分类),迭代器模式也支持多种遍历聚合对象的方法。

迭代器模式强调了如何提供一个简单的接口来顺序访问一组对象,同时隐藏底层的数据结构和遍历的具体实现。正确应用迭代器模式可以使得代码更加灵活和可维护。文章来源地址https://www.toymoban.com/news/detail-847938.html

到了这里,关于设计模式:生活中的迭代器模式的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 设计模式:迭代器模式

    迭代器模式的示例可以涵盖各种数据结构的遍历,包括数组、列表、树、图等。下面是一些不同场景下迭代器模式的示例及其代码实现。 示例 1: 数组遍历 使用迭代器模式遍历数组。 示例 2: 二叉树的深度优先遍历 二叉树的深度优先遍历(使用栈实现)。 示例 3: 分页遍历 在

    2024年04月11日
    浏览(48)
  • 设计模式浅析(十) ·设计模式之迭代器&组合模式

    日常叨逼叨 java设计模式浅析,如果觉得对你有帮助,记得一键三连,谢谢各位观众老爷😁😁 案例 有两家门店,门店A呢只提供早餐,门店B呢只提供午餐,有一天这两家店铺想要进行合并,一起做大做强,再创辉煌。 合并后呢,对于菜单的定制存在了一定的问题: 门店A的

    2024年04月11日
    浏览(47)
  • 设计模式——迭代器模式15

    迭代器模式提供一种方法访问一个容器对象中各个元素,而又不需暴露该对象的内部细节。 设计模式,一定要敲代码理解 迭代器模式将数据存储和数据遍历的职责进行分离。但针对不同结构的迭代对象,迭代方式需进行添加。 代码下载

    2024年04月15日
    浏览(46)
  • Java 设计模式——迭代器模式

    迭代器模式 (Iterator Pattern) 是一种行为型设计模式, 它提供一种顺序访问聚合对象(如列表、集合等)中的元素,而无需暴露聚合对象的内部表示 。迭代器模式将遍历逻辑封装在一个 迭代器对象 中,使得我们可以使用统一的方式遍历不同类型的聚合对象,同时也可以简化客

    2024年02月16日
    浏览(37)
  • 行为型设计模式——迭代器模式

    迭代器模式也是非常的简单, 定义如下: 提供一个对象来顺序访问聚合对象中的一系列数据,而不暴露聚合对象的内部表示。 相信大家都使用过类似下面的迭代器: 如果在你的项目中需要对一个自定义的集合进行迭代遍历,那么迭代器模式是非常需要学习的。迭代器模式主

    2024年01月18日
    浏览(40)
  • 设计模式行为型——迭代器模式

    目录 迭代器模式的定义 迭代器模式的实现 迭代器模式角色 迭代器模式类图 迭代器模式代码实现 迭代器模式的特点 优点 缺点 使用场景 注意事项         迭代器模式(Iterator Pattern)属于行为型模式,其提供一种方法顺序访问一个聚合对象中的各种元素,而又不暴露该对

    2024年02月14日
    浏览(35)
  • 设计模式学习笔记 - 设计模式与范式 -行为型:9.迭代器模式(上):相比直接遍历集合数据,使用迭代器模式有哪些优势?

    上篇文章,我们学习了状态模式。状态模式是状态机的一种实现方式。它通过将事件触发的状态转移和动作执行,拆分到不同的状态类中,以此来避免状态机类中的分支判断逻辑,应对状态机类代码的复杂性。 本章,学习另外一种行为型设计模式,迭代器模式。它用来遍历集

    2024年04月15日
    浏览(56)
  • C++设计模式之迭代器模式

    【声明】本题目来源于卡码网(https://kamacoder.com/) 【提示:如果不想看文字介绍,可以直接跳转到 C++编码部分 】         --什么是迭代器模式(第19种设计模式)          迭代器模式 是⼀种 行为设计模式 ,是⼀种使⽤频率⾮常⾼的设计模式,在各个语⾔中都有应用,

    2024年01月24日
    浏览(37)
  • 《设计模式的艺术》笔记 - 迭代器模式

            迭代器模式提供一种方法来访问聚合对象,而不用暴露这个对象的内部表示,其别名为游标(Cursor)。迭代器模式是一种对象行为型模式。 myclass.h myclass.cpp main.cpp         1. 支持以不同的方式遍历一个聚合对象,在同一个聚合对象上可以定义多种遍历方式。在迭代

    2024年01月24日
    浏览(46)
  • C#设计模式之---迭代器模式

    迭代器模式(Iterator Pattern)是一种对象行为模式,提供一种方法顺序访问一个聚合对象中的各种元素,而又不暴露该对象的内部表示。支持在聚集中移动游标,使得访问聚合中的元素变得简单,简化了聚集的接口,封装了聚合的对象。 迭代器模式还可以应用于对树结构的访

    2024年02月13日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包