技术成神之路:设计模式(十一)迭代器模式

news2024/9/21 4:36:21

前言

迭代器这个词听到并不陌生吧,我们再开发中遍历HashMapHashSet的时候 用到的迭代器和这里的迭代器是一个概念,当然,这个模式不是教你如何去实现的,而是以了解为主。

介绍

迭代器模式(Iterator Pattern)是一种行为型设计模式,它帮助我们在不暴露集合内部结构的情况下,可以顺序访问集合中的元素。它将集合对象的遍历行为抽象出来,放到一个迭代器对象中,这样可以使得遍历行为和集合对象的实现分离。

1. 定义


提供一种方法顺序访问一个聚合对象中的各个元素,而不暴露该对象的内部表示。

2. 主要作用


  • 为各种聚合结构提供一种统一的遍历方法。
  • 使得客户端不需要了解集合的内部结构就可以遍历集合。
  • 分离集合对象的遍历行为,封装在迭代器中。

3. 解决的问题


  • 隐藏集合的内部结构,使得集合的实现和使用分离。
  • 提供一致的遍历接口,方便客户端对不同的集合进行遍历。
  • 使得集合的遍历代码与集合本身解耦,增强代码的可维护性。

4. 模式原理


包含角色:

  1. 迭代器接口(Iterator): 定义访问和遍历元素的接口。
  2. 具体迭代器(Concrete Iterator): 实现迭代器接口,负责遍历集合中的元素。
  3. 聚合接口(Aggregate): 定义创建迭代器对象的接口。
  4. 具体聚合(Concrete Aggregate): 实现聚合接口,创建相应的具体迭代器对象。

UML类图:
在这里插入图片描述
示例代码:

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

// 聚合接口
interface Aggregate<T> {
    Iterator<T> createIterator();
}

// 具体聚合类
class ConcreteAggregate<T> implements Aggregate<T> {
    private List<T> items;

    ConcreteAggregate(List<T> items) {
        this.items = items;
    }

    @Override
    public Iterator<T> createIterator() {
        return new ConcreteIterator<>(items);
    }
}

// 具体迭代器类
class ConcreteIterator<T> implements Iterator<T> {
    private List<T> items;
    private int index;

    ConcreteIterator(List<T> items) {
        this.items = items;
        this.index = 0;
    }

    @Override
    public boolean hasNext() {
        return index < items.size();
    }

    @Override
    public T next() {
        if (!hasNext()) {
            throw new NoSuchElementException();
        }
        return items.get(index++);
    }
}

// 客户端代码
public class Main {
    public static void main(String[] args) {
        List<String> items = List.of("a", "b", "c", "d");
        Aggregate<String> aggregate = new ConcreteAggregate<>(items);
        Iterator<String> iterator = aggregate.createIterator();

        while (iterator.hasNext()) {
            String item = iterator.next();
            System.out.println(item);
        }
    }
}

一眼看去,emm… 好模式,有点绕🤦‍♂️

你只需要知道上面代码的目的就是吧数据 放到 Iterator 中,然后再对数据进行操作就行了

迭代器模式在我们开发中很常见,Java集合框架中的大多数集合类都提供了自己的具体迭代器实现:

  • 迭代器接口:Iterator接口。
  • 具体迭代器:如ArrayList.Itr、HashSet.HashIterator、LinkedList.ListItr等。
  • 聚合接口:Collection接口及其子接口如List、Set、Queue等。
  • 具体聚合:如ArrayList、HashSet、LinkedList等具体集合类。

所以对于我们而言,已经很少会去自己实现迭代器了,因此,对于迭代器模式在于了解而非应用。

5. 优缺点


优点:

  • 简化了遍历集合的操作,客户端不需要了解集合的内部结构。
  • 提供了一致的接口,支持不同类型的集合进行遍历。
  • 分离了集合对象和遍历行为,增强代码的扩展性和可维护性。

缺点:

  • 引入了多个新的接口和实现类,增加了系统的抽象度和理解难度。

6. 应用场景


  1. 需要访问一个聚合对象的内容而无需暴露其内部表示。
  2. 需要为不同类型的聚合对象提供统一的遍历接口。
  3. 需要使用不同的方式遍历一个聚合对象。

上面一直在说 不暴露集合内部结构 可能有人会疑惑,你明明把一个集合都传进去了,内部元素不都暴漏无疑了吗?其实这里的 内部结构 指的是客户端代码不需要知道容器是如何实现数据存储和组织的,只需要通过统一的迭代器接口来访问容器中的元素。

通俗地说,迭代器模式允许你遍历一个集合,而不需要知道集合的底层实现细节。主要是解耦合,因为迭代器模式可以支持多种遍历方式顺序遍历、逆序遍历、跳跃遍历等,完全可以独立出来 自成一派。

7. 总结


迭代器模式提供了一种方法,可以在不暴露集合内部结构的情况下,顺序访问集合中的各个元素。它使得集合对象的遍历行为和集合本身分离,提供了一致的接口,增强了代码的可扩展性和可维护性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1974457.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

携程实习生0506笔试-编程题

解题思路&#xff1a; 看坐标之和&#xff0c;奇数偶数不同字符即可。 解题思路&#xff1a; 题目应该是求连续的k长度最大值&#xff0c;遍历比较字符串&#xff0c;最后再取模。 import java.util.Scanner;public class Main {public static void main(String[] args) {Scann…

Keysight(原Agilent) E4980AL 精密 LCR 表特性与技术指标

Keysight(原Agilent) E4980AL 精密 LCR 表为基础 LCR 表树立了行业标准&#xff0c;可在多个频率范围内提供更佳的精度、速度和通用性。E4980AL 结合了种类繁多的附件&#xff0c;适用于一般研发和生产环境中的各种元件和材料测量。也可通过频率升级而提升投资回报率。 Keysig…

媲美Element Plus JuanTree终极实战:虚拟滚动

JuanTree组件功能迭代终于来到了终章——虚拟滚动实现。 有了前面学习的铺垫&#xff1a;vue大数据量列表渲染性能优化&#xff1a;虚拟滚动原理 把示例的实现用到JuanTree组件就变得非常的简单了。 功能视频演示&#xff1a; 自研Vue3 Tree组件 - 虚拟滚动功能演示 先来看效…

文档在线预览:keking/kkFileView踩坑记

文章目录 一、概述1、官方文档2、使用 二、部署服务1、传统部署方式&#xff08;1&#xff09;环境要求&#xff08;2&#xff09;生成部署包 2、docker部署方式 三、踩坑1、预览并发问题&预览首次打开慢2、字体问题乱码3、水印问题4、使用nginx代理5、docker部署指定配置 …

stm32 RAM for Algorithm问题,已解决

在此界面将 programming Algorithm内的flash remove&#xff0c;然后再重选就能解决

Drools

Drools基本了解 谈谈对业务规则管理系统的了解 举例说明 规则引擎系统是一个规则管理系统&#xff0c;接受数据输入、解释业务规则、根据业务规则做出业务决策的一个系统&#xff0c;其适用场景有贷款风险评估、积分优惠系统、保险理赔系统。规则是由“条件动作”组成&#x…

雅萌五代射频仪拆机图

雅萌五代射频仪拆机图&#xff0c;相对之前的版本&#xff0c;这个射频仪的头部电极部分&#xff0c;进行结构的优化&#xff0c;整个面比较平整光滑&#xff0c;不容易残留凝胶

allegro学习之一

1&#xff09;favorite设置界面 2&#xff09;双单位显示界面设置 3&#xff09;高亮实心显示 4&#xff09;自己设置的favorite 5&#xff09;导线圆滑显示 6&#xff09;plane的使用场景 7&#xff09;add to visibility的方法 8&#xff09;net group的使用 效果图如下&am…

实施运维方案(Word原件)

编写目的&#xff1a; 作为项目运维服务质量管理的总纲&#xff0c;规范和指导公司运维服务质量管理&#xff0c;加强运维服务质量管理的有效性。保证运维服务的整体质量&#xff0c;提升公司运维服务的整体质量水平。使公司能够为客户提供更高质量的运维服务&#xff0c;保障公…

【优选赛事】2024年iCAN大赛AI视觉检测设计挑战赛

iCAN大学生创新创业大赛(以下简称“iCAN大赛”")是一个无固定限制、鼓励原始创新的赛事&#xff0c;自2007年发起至今&#xff0c;得到了广大青年学生的热爱。2010年&#xff0c;iCAN大赛获批《教育部、财政部关于批准2010年度大学生竞赛资助项目的通知》大学生竞赛资助项…

Windows上安装EMQX作为MQTT服务器以及配置MQTTX客户端

一、安装EMQX MQTT服务器 EMQX 是一个高性能、可扩展的物联网消息中间件&#xff0c;EMQX 实现了 MQTT 协议的服务器端&#xff0c;即 MQTT Broker&#xff0c;它负责接收来自客户端的连接请求&#xff0c;处理订阅、发布消息&#xff0c;并将消息转发给相应的订阅者。 下载E…

大模型训练流程解析

版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl训练大模型是一个复杂且资源密集的过程,它不仅仅要求大量的计算资源和时间,还涉及多个关键步骤和要素。这个过程需要从数据的收集、清洗、整理到模型的设计与选择,再到模型的训练、评估与优化,…

Netty4自学笔记 (3) - Netty NIO Server和Client 样例说明

全文详见个人独立博客&#xff1a;Netty4自学笔记 (3) - Netty NIO Server和Client 样例说明 Netty4自学笔记 (3) - Netty NIO Server和Client 样例说明更新节奏缓慢&#xff0c;因为每晚学习注意力不够集中&#xff0c;学习进展缓慢。本还给自己找了一大堆其他理由&#xff0…

tof系统标定流程之双频测距与代码详解

tof系统标定流程之双频测距目录 1、双频测距原理2、双频测距流程3、双频测距代码1、双频测距原理 为什么需要双频测距,只用一个频率测距不行吗?实际上一个频率的测距范围有限,以100MHZ/80MHZ/10MHZ/15MHZ的频率为例,其测距范围分别是1.5m,1.875m,15m,10m,频率越低测距范围…

TypeError: ‘dict’ object is not callable 深度解析

TypeError: ‘dict’ object is not callable 深度解析 在Python编程中&#xff0c;TypeError: dict object is not callable是一个常见的错误&#xff0c;通常发生在尝试调用一个字典对象时。这个错误表明代码中存在逻辑错误&#xff0c;可能是将字典误用为函数或方法。本文将…

C++第六篇 模板初阶和STL简介

目录 一&#xff0c;模板初阶 1.泛型编程 2.函数模板 2.1 函数模板概念 2.2 函数模板格式 2.3 函数模板的原理 2.4 函数模板的实例化 2.5 模板参数的匹配原则 3.类模板(模板类&#xff0c;模板函数) 3.1 类模板定义格式 二&#xff0c;STL简介 1. 什么是STL 2. ST…

[环境配置]Pycharm:Failed to start [PowerShell.exe]

解决方法&#xff0c;点Local旁边的 号&#xff0c;点击Command Prompt&#xff0c;即可在Pycharm中呼出控制台。 如果要修改Command Prompt的启动时访问的cmd.exe的路径&#xff0c;可以去Settings→Tools→Terminal中&#xff0c;修改Shell Path实现&#xff0c;改为cmd.exe…

「AI绘画Stable Diffusion 零基础入门 」AI 绘画SD原理与工具介绍,万字详解新手入门必看!

大家好&#xff0c;我是设计师阿威 AI 绘画原理 想要入门 AI 绘画&#xff0c;首先需要了解它的原理是什么样的。 其实很早就已经有人基于深度学习模型展开了对图像生成的研究了&#xff0c;但在那时&#xff0c;生成的图像分辨率和内容都非常抽象。 直到近两年&#xff0c…

CentOS 8挂载本地源

CentOS 8挂载本地源 1.虚拟机连接centos镜像2.系统查看centos镜像是否在连接上3. 挂载ISO镜像4.配置YUM源1. 备份现有YUM源配置2. 创建新的YUM源配置文件3. 清理YUM缓存并重新生成 5.验证YUM源 1.虚拟机连接centos镜像 2.系统查看centos镜像是否在连接上 [rootlocalhost ~]# l…

【wiki知识库】07.用户管理后端SpringBoot部分

目录 一、今日目标 二、&#x1f388;SpringBoot部分类的添加 2.1 使用逆向工程新增User模块 2.2 UserQueryParam添加 2.3 UserSaveParam添加 2.4 UserResetPasswordParam添加 2.5 UserQueryVo添加 2.6 SnowFlake工具类 三、&#x1f686;后端新增接口 3.1 /user/li…