【设计模式-迭代】

devtools/2024/9/25 13:13:35/

定义

迭代器模式(Iterator Pattern)是一种行为型设计模式用于提供一种顺序访问集合对象元素的方式,而不暴露该对象的内部表示。通过迭代器,客户端可以在不需要了解集合实现的细节的情况下遍历集合中的元素。

UML图

在这里插入图片描述
角色

  • Iterator(迭代器接口):定义了访问和遍历集合元素的方法,如 next()、hasNext() 等。
  • ConcreteIterator(具体迭代器):实现迭代器接口,维护对集合的引用,并提供遍历集合的具体逻辑。
  • Aggregate(聚合接口):定义创建迭代器的接口,通常有一个方法返回一个迭代器实例。
  • ConcreteAggregate(具体聚合类):实现聚合接口,维护集合的内部数据结构,并提供创建具体迭代器的方法。

流程

  1. 客户端请求聚合对象的迭代器。
  2. 迭代器返回一个具体的迭代器实例,客户端使用该迭代器访问集合元素。
  3. 迭代器提供的方法用于遍历集合,不需要客户端了解集合的具体实现。

代码

java">import java.util.ArrayList;
import java.util.List;// 迭代器接口
interface Iterator<T> {boolean hasNext();T next();
}// 聚合接口
interface Aggregate<T> {Iterator<T> createIterator();
}// 具体迭代器
class ConcreteIterator<T> implements Iterator<T> {private List<T> items;private int position = 0;public ConcreteIterator(List<T> items) {this.items = items;}@Overridepublic boolean hasNext() {return position < items.size();}@Overridepublic T next() {return hasNext() ? items.get(position++) : null;}
}// 具体聚合类
class ConcreteAggregate<T> implements Aggregate<T> {private List<T> items = new ArrayList<>();public void addItem(T item) {items.add(item);}@Overridepublic Iterator<T> createIterator() {return new ConcreteIterator<>(items);}
}// 测试迭代器模式
public class IteratorPatternDemo {public static void main(String[] args) {ConcreteAggregate<String> aggregate = new ConcreteAggregate<>();aggregate.addItem("Item 1");aggregate.addItem("Item 2");aggregate.addItem("Item 3");Iterator<String> iterator = aggregate.createIterator();while (iterator.hasNext()) {System.out.println(iterator.next());}}
}

优点

  • 解耦:客户端与集合的内部表示解耦,客户端只需关注如何使用迭代器,而无需关心集合的具体实现。
  • 多种遍历方式:可以为同一集合提供多种不同的迭代器,支持不同的遍历策略。
  • 简化集合接口:将遍历功能抽象为迭代器,使集合接口更简单,关注于集合本身的操作。

缺点

  • 增加系统复杂性:引入迭代器模式会增加系统中的类数量,可能导致代码复杂性提高。
  • 性能开销:在某些情况下,使用迭代器可能引入额外的性能开销。

适用场景

  • 需要访问集合中的元素:如列表、集合、树等数据结构的遍历。
  • 不同遍历方式的需求:当同一集合需要多种遍历方式时,迭代器模式非常适用。
  • 对集合的封装:希望隐藏集合的内部结构,提供统一的访问接口时。

http://www.ppmy.cn/devtools/116979.html

相关文章

mysql查询某个库下所有表的数据量

要查询MySQL数据库下指定数据库的所有表的数据量&#xff08;即每个表中的记录数&#xff09;&#xff0c;可以使用以下步骤&#xff1a; 1&#xff09;连接到MySQL数据库&#xff1a;首先&#xff0c;你需要使用MySQL客户端或任何支持MySQL连接的编程语言&#xff08;如Pytho…

WebSocket实现在线聊天室

项目实现源码&#xff1a; 前端源码 后端源码 1.常见的消息推送方式 1.1 轮询 1.1.1 轮询的概念 客户端以固定的事件间隔&#xff08;例如每秒或几分钟&#xff09;向服务器发送HTTP请求&#xff0c;服务器收到请求后&#xff0c;处理请求并返回数据给客户端 轮询具体实现htt…

Android外接USB扫码枪

前言 公司的设备以前接入的都是串口的扫码头&#xff0c;优点是直接通过串口读取流里面的数据就OK了&#xff0c;缺点是你需要知道每一款扫码器的型号以获取波特率及Android设备的串口地址。因为现在usb扫码器越来越方便且即插即用&#xff0c;不需要额外供电以及价格便宜等特…

STM32CubeIDE | 使用HAL库的ADC读取内部传感器温度

1、cubemx配置 1.1、系统配置 1.2、GPIO配置 PB2设置为“GPIO_Output” user label设置为“LED” 1.3、串口配置 模式选择为“Asynchronous”&#xff0c;其他默认 1.4、时钟树配置 全部保持默认 2、ADC配置 通道选择“Temperature Sensor Channel”&#xff0c;其他默认 …

Python Web 与物联网(IoT)集成与实时数据处理

Python Web 与物联网&#xff08;IoT&#xff09;集成与实时数据处理 目录 &#x1f310; IoT 与 Python 的集成&#x1f4e1; 使用 Flask/FastAPI 构建 IoT 中的 Web 接口与控制面板&#x1f517; 使用 MQTT 协议与 Paho 库进行设备间通信&#x1f5c4;️ 在 Python 中处理传…

【html】基础(二)

本专栏内容为&#xff1a;前端专栏 记录学习前端&#xff0c;分为若干个子专栏&#xff0c;html js css vue等 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;js专栏 &#x1f69a;代码仓库&#xff1a;小小unicorn的代码仓库&#x1f69a; &am…

【学习笔记】Transformer架构探讨

Transformer 是一种彻底改变人工智能方法的神经网络架构。它首次在 2017 年的里程碑式论文 "Attention is All You Need"[1] 中被提出&#xff0c;并迅速成为深度学习模型的首选架构&#xff0c;为 OpenAI 的 GPT、Meta 的 Llama 和 Google 的 Gemini 等文本生成模型…

js中正则表达式中【exec】用法深度解读

exec() 是 JavaScript 正则表达式对象&#xff08;RegExp&#xff09;中的一个方法&#xff0c;用于匹配字符串中的特定模式&#xff0c;并返回匹配结果。它比 test() 和 match() 更强大&#xff0c;因为它不仅仅返回匹配成功与否&#xff0c;还返回匹配的具体内容及其相关信息…