码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 设计模式18—— 迭代器模式


    写文章的初心主要是用来帮助自己快速的回忆这个模式该怎么用,主要是下面的UML图可以起到大作用,在你学习过一遍以后可能会遗忘,忘记了不要紧,只要看一眼UML图就能想起来了。同时也请大家多多指教。

    迭代器模式(Iterator)

    是一种行为型模式。

    目录

    一、概述

    1.1、直观的理解装饰模式要干什么:

    1.2、主要的角色:

    1.3、描述对象之间关系的UML图:

    1.4、适用场景:

    二、举例

    2.1、对象之间的关系用UML图表示如下:

    2.2、Java代码如下:


    一、概述

    1、提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示。
    2、当你需要访问一个聚集(合)对象,而且不管这些对象是什么都需要遍历的时候,你就应该考虑用迭代器模式。
    3、当你需要对聚集(合)有多种方式遍历时,可以考虑用迭代器模式。
    4、为遍历不同的聚集(合)结构提供如开始、下一个、是否结束、当前哪一项等统一的接口。
    5、分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合的内部结构,又可以让外部代码透明地访问集合内部的数据。

    1.1、直观的理解装饰模式要干什么:

    (注,常见的聚合或聚集的对象有:数组、队列、栈、树、图等等)

    迭代器几乎在所有面向对象语言中都存在,就比如某些情况下使用for循环遍历数组,它也是用到了迭代器模式,只不过被封装了而已。

    1.2、主要的角色:

    • 聚合:聚合的抽象类或接口 + 具体的聚合
    • 迭代器:迭代器的抽象类或接口 + 具体的迭代器

    1.3、描述对象之间关系的UML图:

    1.4、适用场景:

    • 需要访问一个聚合对象的内容,并且不暴露它的内部表示
    • 支持对聚合对象的多种遍历
    • 为遍历不同的聚合结构提供一个统一接口,可以更好的使用多态的特性

    二、举例

    假设要遍历一个动态数组,本例比较简单,你可以把这当做一个模板,然后灵活使用:

    2.1、对象之间的关系用UML图表示如下:

    2.2、Java代码如下:

    聚合的抽象类:

    1. abstract class Aggregate {
    2. public abstract Iterator createIterator();//创建迭代器
    3. }

    迭代器的抽象类:

    1. abstract class Iterator {
    2. public abstract Object first();//获得第一个元素
    3. public abstract Object next();//获得下一个元素
    4. public abstract boolean isDone();//判断是否到结尾
    5. public abstract Object currentItem();//获得当前元素
    6. }

    具体的聚合类:

    1. public class ConcreteAggregate extends Aggregate {
    2. private ArrayList items = new ArrayList<>(); //动态数组
    3. @Override
    4. public Iterator createIterator() {//创建迭代器
    5. return new ConcreteIterator(this);
    6. }
    7. public int getCount() {//返回聚集里的元素个数
    8. return items.size();
    9. }
    10. public void add(Object o) {//添加新元素
    11. items.add(o);
    12. }
    13. public Object getItemByIndex(int index) {//根据下标返回元素
    14. return items.get(index);
    15. }
    16. }
    17. 具体的迭代器类:

      1. public class ConcreteIterator extends Iterator {
      2. private ConcreteAggregate aggregate;//聚集类
      3. private int current = 0;//标志当前位置
      4. public ConcreteIterator(ConcreteAggregate aggregate) {//初始化,将聚集传递给当前迭代器
      5. this.aggregate = aggregate;
      6. }
      7. @Override
      8. public Object first() {//获得第一个元素
      9. return aggregate.getItemByIndex(0);
      10. }
      11. @Override
      12. public Object next() {//获得下一个元素
      13. Object ret = null;
      14. current++;
      15. if (current < aggregate.getCount()) {
      16. ret = aggregate.getItemByIndex(current);
      17. }
      18. return ret;
      19. }
      20. @Override
      21. public boolean isDone() {//判断是否到结尾
      22. return current >= aggregate.getCount();
      23. }
      24. @Override
      25. public Object currentItem() {//获得当前元素
      26. return aggregate.getItemByIndex(current);
      27. }
      28. }

      主程序(发起请求的类):

      1. public class Main {
      2. public static void main(String[] args) {
      3. //创建聚合
      4. ConcreteAggregate concreteAggregate = new ConcreteAggregate();
      5. concreteAggregate.add("张三");
      6. concreteAggregate.add("李四");
      7. concreteAggregate.add("王五");
      8. concreteAggregate.add("老六");
      9. //创建迭代器
      10. Iterator iterator = concreteAggregate.createIterator();
      11. //开始遍历聚合
      12. iterator.first();
      13. while (!iterator.isDone()) {
      14. System.out.println(iterator.currentItem());
      15. iterator.next();
      16. }
      17. }
      18. }

      这里就不再举例了,可以把上面的Java例子复制到你本地,运行main函数试一下加深理解。这些代码都是我自己学习的时候根据一些教材手敲的,不存在bug可以直接运行。

      如果觉得本文还不错,就请点个赞给作者一点鼓励吧!如果有建议,也请评论指教和讨论!

    18. 相关阅读:
      【基于React-Native做位置信息获取,并展示出来】
      Android12之仿Codec2.0实现传递编解码器组件本质(四十六)
      【MapStruct】对象转换
      高并发技巧-流量聚合和高并发写入处理技巧
      pytest
      计算机毕业设计之java+ssm网上出差审批与费用报销系统
      最长公共子序列(最详细的动态规划案例)
      一天吃透Redis面试八股文
      (二)库存计划-经济订货量(EOQ)
      微信小程序手机号快速验证组件调用方式
    19. 原文地址:https://blog.csdn.net/weixin_43687024/article/details/139253804
      • 最新文章
      • 攻防演习之三天拿下官网站群
        数据安全治理学习——前期安全规划和安全管理体系建设
        企业安全 | 企业内一次钓鱼演练准备过程
        内网渗透测试 | Kerberos协议及其部分攻击手法
        0day的产生 | 不懂代码的"代码审计"
        安装scrcpy-client模块av模块异常,环境问题解决方案
        leetcode hot100【LeetCode 279. 完全平方数】java实现
        OpenWrt下安装Mosquitto
        AnatoMask论文汇总
        【AI日记】24.11.01 LangChain、openai api和github copilot
      • 热门文章
      • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
        奉劝各位学弟学妹们,该打造你的技术影响力了!
        五年了,我在 CSDN 的两个一百万。
        Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
        面试官都震惊,你这网络基础可以啊!
        你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
        心情不好的时候,用 Python 画棵樱花树送给自己吧
        通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
        13 万字 C 语言从入门到精通保姆级教程2021 年版
        10行代码集2000张美女图,Python爬虫120例,再上征途
      Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
      正则表达式工具 cron表达式工具 密码生成工具

      京公网安备 11010502049817号