【设计模式】我终于读懂了迭代器模式。。。

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

看一个具体的需求

编写程序展示一个学校院系结构:需求是这样
要在一个页面中展示出学校的院系组成,
一个学校有多个学院,
一个学院有多个系。

如图:

【设计模式】我终于读懂了迭代器模式。。。

传统的设计方案(类图)

【设计模式】我终于读懂了迭代器模式。。。

传统的方式的问题分析

  1. 将学院看做是学校的子类,系是学院的子类,这样实际上是站在组织大小来进行分层次的

  2. 实际上我们的要求是 :在一个页面中展示出学校的院系组成,一个学校有多个学院,一个学院有多个系, 因此这种方案,不能很好实现的遍历的操作

  3. 解决方案:=> 迭代器模式

迭代器模式基本介绍

  1. 迭代器模式(Iterator Pattern)是常用的设计模式,属于行为型模式
  2. 如果我们的集合元素是用不同的方式实现的,有数组,还有 java 的集合类,或者还有其他方式,当客户端要遍历这些集合元素的时候就要使用多种遍历方式,而且还会暴露元素的内部结构,可以考虑使用迭代器模式解决。
  3. 迭代器模式,提供一种遍历集合元素的统一接口,用一致的方法遍历集合元素,不需要知道集合对象的底层表示,即:不暴露其内部的结构。

迭代器模式的原理类图

【设计模式】我终于读懂了迭代器模式。。。

对原理类图的说明-即(迭代器模式的角色及职责)

  1. Iterator : 迭代器接口,是系统提供,含义 hasNext, next, remove
  2. ConcreteIterator : 具体的迭代器类,管理迭代
  3. Aggregate :一个统一的聚合接口, 将客户端和具体聚合解耦
  4. ConcreteAggreage : 具体的聚合持有对象集合, 并提供一个方法,返回一个迭代器, 该迭代器可以正确遍历集合
  5. Client :客户端, 通过 Iterator 和 Aggregate 依赖子类

迭代器模式应用实例

编写程序展示一个学校院系结构:需求是这样,
要在一个页面中展示出学校的院系组成,
一个学校有多个学院,
一个学院有多个系。

【设计模式】我终于读懂了迭代器模式。。。

College类,学院超类

【设计模式】我终于读懂了迭代器模式。。。

ComputerCollege类,计算机学院

【设计模式】我终于读懂了迭代器模式。。。

里面的专业(Department)是以数组方式存储的

Department类

【设计模式】我终于读懂了迭代器模式。。。

InfoCollege类,信息工程学院

【设计模式】我终于读懂了迭代器模式。。。
这里面的专业(Department)是以列表方式存储的

ComputerCollegeIterator类,计算机学院具体迭代类,需要实现Iterator接口

【设计模式】我终于读懂了迭代器模式。。。

InfoColleageIterator类,信息工程学院具体迭代类,需要实现Iterator接口

【设计模式】我终于读懂了迭代器模式。。。

OutPutImpl类,统一打印信息

【设计模式】我终于读懂了迭代器模式。。。

Client类,客户端类

【设计模式】我终于读懂了迭代器模式。。。

运行结果

【设计模式】我终于读懂了迭代器模式。。。

老规矩,debug看看

【设计模式】我终于读懂了迭代器模式。。。

这里构建了一个含有计算机学院和信息工程学院的list传入到OutPutImpl的构造函数中去

【设计模式】我终于读懂了迭代器模式。。。
可以看到outPutImpl被实例之后的对象含有一个列表成员变量

进入printCollege方法

【设计模式】我终于读懂了迭代器模式。。。

这里调用的是list里面的Iterator拿出每个学院出来,并且打印名称

【设计模式】我终于读懂了迭代器模式。。。

college.createIterator()方法

【设计模式】我终于读懂了迭代器模式。。。
【设计模式】我终于读懂了迭代器模式。。。

这里返回了一个具体的迭代器

【设计模式】我终于读懂了迭代器模式。。。
【设计模式】我终于读懂了迭代器模式。。。

再回到printDepartment方法

【设计模式】我终于读懂了迭代器模式。。。

这里的迭代器是一个计算机学院迭代器

【设计模式】我终于读懂了迭代器模式。。。

所以他就会走我们自己的实现

【设计模式】我终于读懂了迭代器模式。。。

接着拿到专业

【设计模式】我终于读懂了迭代器模式。。。

输出专业名称

【设计模式】我终于读懂了迭代器模式。。。

信息工程学院亦是如此

这样OutPutImpl这个类其实并不知道具体的迭代器是什么,就将我们的内部细节给隐藏起来了

迭代器模式在JDK中的源码分析

JDK 的 ArrayList 集合中就使用了迭代器模式

代码分析

ArrayList类

【设计模式】我终于读懂了迭代器模式。。。

ArrayList的iterator方法

【设计模式】我终于读懂了迭代器模式。。。

返回了一个Itr类

他是ArrayList里面的实现了iterator的内部类

【设计模式】我终于读懂了迭代器模式。。。

他存在的成员变量elementData存储数据

【设计模式】我终于读懂了迭代器模式。。。

然后我们看看linkedlist

【设计模式】我终于读懂了迭代器模式。。。

他的父类AbstractSequentialList有一个iterator方法

【设计模式】我终于读懂了迭代器模式。。。

实际调用的是AbstractSequentialList的父类AbstractList里面的listIterator方法

【设计模式】我终于读懂了迭代器模式。。。

实际返回的是AbstractList内部类ListItr

【设计模式】我终于读懂了迭代器模式。。。

对类图的角色分析和说明

【设计模式】我终于读懂了迭代器模式。。。

  1. 内部类 Itr 充当具体实现迭代器 Iterator 的类, 作为 ArrayList 内部类,类似ConcreteIterator
  2. List 就是充当了聚合接口,含有一个 iterator() 方法,返回一个迭代器对象,类似Aggregate
  3. ArrayList 是实现聚合接口 List 的子类,实现了 iterator(),类似ConcreteAggreage
  4. Iterator 接口系统提供

迭代器模式解决了 不同集合(ArrayList ,LinkedList) 统一遍历问题

迭代器模式的注意事项和细节

优点

  1. 提供一个统一的方法遍历对象,客户不用再考虑聚合的类型,使用一种方法就可以遍历对象了。
  2. 隐藏了聚合的内部结构,客户端要遍历聚合的时候只能取到迭代器,而不会知道聚合的具体组成。
  3. 提供了一种设计思想,就是一个类应该只有一个引起变化的原因(叫做单一责任原则)。在聚合类中,我们把迭代器分开,就是要把管理对象集合和遍历对象集合的责任分开,这样一来集合改变的话,只影响到聚合对象。而如果遍历方式改变的话,只影响到了迭代器。
  4. 当要展示一组相似对象,或者遍历一组相同对象时使用, 适合使用迭代器模式

缺点

  1. 每个聚合对象都要一个迭代器,会生成多个迭代器不好管理类

资料参考:https://www.bilibili.com/video/BV1G4411c7N4

代码地址:https://gitee.com/WangFuGui-Ma/design-pattern/tree/master/design文章来源地址https://www.toymoban.com/news/detail-431698.html

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

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

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

相关文章

  • 设计模式:迭代器模式

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

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

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

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

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

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

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

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

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

    2024年02月14日
    浏览(35)
  • Java 设计模式——迭代器模式

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

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

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

    2024年04月15日
    浏览(56)
  • 一文带你读懂设计模式之责任链模式

    emm,翻了一下之前刚入职时候的学习笔记,发现之前在熟悉业务代码的时候曾经专门学习并整理过过设计模式中的 责任链模式 ,之前只是对其简单了解过常用的设计模式有哪些,并未结合实例和源码深入对其探究,利用熟悉代码契机进行系统学习并整理文档如下。 俗话说没

    2024年02月12日
    浏览(44)
  • C++设计模式之迭代器模式

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

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

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

    2024年02月13日
    浏览(49)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包