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


    文章目录

    • 迭代器模式基本介绍
    • 迭代器模式的原理类图
    • 对原理类图的说明-即(迭代器模式的角色及职责)
    • 迭代器模式应用实例
    • 迭代器模式在 JDK-ArrayList 集合应用的源码分析
    • 迭代器模式的注意事项和细节
      • 优点
      • 缺点

    迭代器模式基本介绍

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

    迭代器模式的原理类图

    在这里插入图片描述

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

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

    迭代器模式应用实例

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

    在这里插入图片描述

    1. 设计思路分析

    类图:

    在这里插入图片描述

    1. 代码实现

    https://gitee.com/luan_hao/design-pattern/tree/master/src/main/java/com/lh/iterator

    迭代器模式在 JDK-ArrayList 集合应用的源码分析

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

    2. 类图

    在这里插入图片描述

    1. 对类图的角色分析和说明

      • 内部类 Itr 充当具体实现迭代器 Iterator 的类, 作为 ArrayList 内部类
      • List 就是充当了聚合接口,含有一个 iterator() 方法,返回一个迭代器对象
      • ArrayList 是实现聚合接口 List 的子类,实现了 iterator()
      • Iterator 接口系统提供迭代器模式解决了 不同集合(ArrayList ,LinkedList) 统一遍历问题

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

    优点

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

    缺点

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

  • 相关阅读:
    Leetcode33. Search in Rotated Sorted Array | Binary Search
    关于硬件原理图
    Python安装教程
    软件测试(测试用例攻略)—写用例无压力
    latex编译生成的pdf文件,图片出现浅色的线
    奋战开源操作系统二十年:为什么编程语言是突破口?
    Systemverilog中使用interface连接testbench和dut的端口
    leecode#Excel表列序号#组合两个表
    mysql数据库进阶
    【Spring boot 读取系统环境变量】
  • 原文地址:https://blog.csdn.net/weixin_45417821/article/details/133146040
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号