设计模式- 迭代器模式(Iterator Pattern)结构|原理|优缺点|场景|示例

ops/2024/12/23 7:16:33/

                                     设计模式(分类)        设计模式(六大原则)   

    创建型(5种)        工厂方法         抽象工厂模式        单例模式        建造者模式        原型模式

    结构型(7种)        适配器模式        装饰器模式        代理模式        ​​​​​​外观模式      桥接模式        组合模式       享元模式

    行为型(11种)      策略模式        模板方法模式        观察者模式        迭代器模式     责任链模式     命令模式    备忘录模式          状态模式         访问者模式        中介者模式 


迭代器模式(Iterator Pattern)是一种行为设计模式,它提供了一种方法来顺序访问聚合对象(容器)中的元素,而又不暴露其实现细节。通过使用迭代器,用户可以从不同类型的聚合对象中以统一的方式遍历元素,而无需了解聚合物的内部结构或其存储方式。

结构:

  • Iterator(迭代器)接口: 定义了访问和遍历元素所需的抽象方法,如 hasNext()(是否有下一个元素)、next()(获取下一个元素)等。
  • ConcreteIterator(具体迭代器): 实现了迭代器接口,跟踪当前的遍历位置,并通过与聚合物的具体实现协作来提供对下一个元素的访问。
  • Aggregate(聚合)接口/抽象类: 定义了创建迭代器对象的接口方法,如 createIterator()
  • ConcreteAggregate(具体聚合): 具体的聚合类,提供了具体的元素存储结构,并实现了创建相应迭代器的方法。

原理:

迭代器模式的工作原理在于,它为聚合对象提供了一种标准的方式来访问内部元素,而无需暴露任何内部的数据结构。通过使用迭代器,用户可以通过简单的接口控制遍历过程,比如逐个获取元素,直到遍历结束。

优缺点:

  • 优点
    • 封装性好,隐藏了集合内部表示,简化了客户端代码。
    • 提供了统一的遍历各种聚合结构的方法,易于扩展和替换不同的数据结构。
    • 支持多种遍历方式,如正向、反向遍历等。
  • 缺点
    • 对于不同的聚合结构,可能需要编写不同的迭代器,增加了类的数量。
    • 迭代器模式只提供了一种线性访问方式,复杂的随机访问可能需要额外的设计。
    • 如果迭代器本身比较复杂,可能会增加系统的理解难度和维护成本。

场景:

  • 当需要遍历集合、数组或其他容器中的元素时。
  • 当希望提供多种遍历方式(顺序、条件等)时。
  • 在不希望暴露集合内部结构或实现细节的情况下,对外提供一致的访问接口。

代码示例(以Java为例)

// 聚合接口
public interface Collection {Iterator createIterator();
}// 具体聚合类
public class ConcreteCollection implements Collection {private Object[] items;public Iterator createIterator() {return new ConcreteIterator(this);}// ... 其他实现细节 ...
}// 迭代器接口
public interface Iterator {boolean hasNext();Object next();
}// 具体迭代器类
public class ConcreteIterator implements Iterator {private Collection collection;private int position = 0;public ConcreteIterator(Collection collection) {this.collection = collection;}@Overridepublic boolean hasNext() {return position < collection.size();}@Overridepublic Object next() {if (!hasNext()) {throw new NoSuchElementException();}return collection.getItem(position++);}// ... 其他实现细节 ...
}// 使用示例
public class Client {public static void main(String[] args) {Collection col = new ConcreteCollection();// ... 初始化集合 ...Iterator it = col.createIterator();while (it.hasNext()) {Object item = it.next();System.out.println(item);}}
}

http://www.ppmy.cn/ops/23946.html

相关文章

Linux的FTP服务

目录 1.什么是FTP服务&#xff1f; 2.FTP的工作原理和流程 1 主动模式 2 被动模式 3.搭建和配置FTP服务 1 下载服务包、备份配置文件 2 修改配置文件​编辑 3 匿名访问测试 4 设置黑白命令 1.什么是FTP服务&#xff1f; FTP&#xff08;file Transfer Protocol&#…

【大数据】分布式数据库HBase

目录 1.概述 1.1.前言 1.2.数据模型 1.3.列式存储的优势 2.实现原理 2.1.region 2.2.LSM树 2.3.完整读写过程 2.4.master的作用 1.概述 1.1.前言 本文式作者大数据系列专栏中的一篇文章&#xff0c;按照专栏来阅读&#xff0c;循序渐进能更好的理解&#xff0c;专栏…

typora中如何使用cos存储

上传工具 https://toolinbox.net/iPic/ 腾讯云的cos存储 https://console.cloud.tencent.com/cos/bucket?actioncreate cos防盗指引 对象存储 防盗刷指引-最佳实践-文档中心-腾讯云 cos计费规则 对象存储 流量费用-购买指南-文档中心-腾讯云 其他方法可以参考 Typora等mar…

【每日刷题】Day28

【每日刷题】Day28 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f34d; &#x1f33c;文章目录&#x1f33c; ​ 1. 121. 买卖股票的最佳时机 - 力扣&#xff08;LeetCode&#xff09; 2. 205. 同构字符串 - 力扣…

[C++基础学习]----02-C++运算符详解

前言 C中的运算符用于执行各种数学或逻辑运算。下面是一些常见的C运算符及其详细说明&#xff1a;下面详细解释一些常见的C运算符类型&#xff0c;包括其原理和使用方法。 正文 01-运算符简介 算术运算符&#xff1a; a、加法运算符&#xff08;&#xff09;&#xff1a;对两个…

【Hive】自定义函数从编写到应用的整个流程(以UDF为例)

1. 编写UDF程序 以Java为例&#xff0c;编写一个字符串反转的函数&#xff08;工程依赖部分略&#xff09;&#xff1a; package com.example;import org.apache.hadoop.hive.ql.exec.UDF; import org.apache.hadoop.hive.ql.exec.Description; import org.apache.hadoop.hiv…

LORA详解

第一章、lora论文解析 参考论文&#xff1a; low rank adaption of llm 背景介绍&#xff1a; 自然语言处理的一个重要范式包括对一般领域数据的大规模预训练和对特定任务或领域的适应处理。在自然语言处理中的许多应用依赖于将一个大规模的预训练语言模型适配到多个下游应用…

LabVIEW 2024安装教程(附免费安装包资源)

鼠标右击软件压缩包&#xff0c;选择“解压到LabVIEW.2024”。 返回解压后的文件夹&#xff0c;鼠标右击“ni_labview-2024”选择“装载”。 鼠标右击“Install”选择“以管理员身份运行”。 点击“我接受上述2条许可协议”&#xff0c;然后点击“下一步”。 点击“下一步”。 …