当前位置: 首页 > article >正文

23中设计模式-迭代器(Iterator)设计模式

迭代器设计模式

  • 🚩什么是迭代器设计模式?
  • 🚩迭代器设计模式的特点
  • 🚩迭代器设计模式的结构
  • 🚩迭代器设计模式的优缺点
  • 🚩迭代器设计模式的Java实现
  • 🚩代码总结
  • 🚩总结

🚩什么是迭代器设计模式?

迭代器设计模式(Iterator Pattern) 是一种 行为型设计模式,它提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示。迭代器模式将遍历数据的职责从聚合对象中分离出来,使得聚合对象可以更专注于数据存储,而迭代器则专注于遍历数据。

使用场景

  • 访问一个聚合对象的内容而无需暴露其内部表示

  • 为聚合对象提供多种遍历方式

  • 为不同的聚合结构提供统一的遍历接口

  • 适用于 集合类树形结构图结构 等数据结构的遍历

🚩迭代器设计模式的特点

  • 分离集合对象的遍历行为:将遍历算法与集合对象分离

  • 多种遍历方式:可以为同一个聚合对象提供多种遍历方式

  • 统一的遍历接口:为不同的聚合结构提供统一的遍历接口

  • 简化聚合接口:聚合对象不需要提供多种遍历方法

  • 并行遍历:支持对同一聚合对象的多个同时遍历

🚩迭代器设计模式的结构

迭代器模式主要包含以下部分:

  • Iterator(迭代器接口):定义访问和遍历元素的接口

  • ConcreteIterator(具体迭代器):实现迭代器接口,跟踪当前访问位置

  • Aggregate(聚合接口):定义创建相应迭代器对象的接口

  • ConcreteAggregate(具体聚合):实现创建相应迭代器的接口

  • Client(客户端):通过迭代器遍历聚合对象

图例:

在这里插入图片描述

🚩迭代器设计模式的优缺点

✅ 优点

  • 支持多种遍历方式:可以同时使用不同的方式遍历同一个聚合

  • 简化聚合类:将遍历逻辑从聚合类中分离出来

  • 符合单一职责原则:将管理集合和遍历集合的职责分离

  • 符合开闭原则:可以新增迭代器而无需修改聚合类

  • 隐藏内部实现:客户端无需知道聚合的内部结构

❌ 缺点

  • 增加系统复杂度:对于简单的聚合可能过度设计

  • 性能开销:迭代器模式可能会带来一定的性能开销

  • 增加类的数量:每个聚合类都需要对应的迭代器类

🚩迭代器设计模式的Java实现

代码地址:GitHub

  • 创建 Book 类(聚合元素)
/*** @author hanson.huang* @version V1.0* @ClassName Book* @Description 书籍类 - 聚合中的元素* @date 2025/3/25 19:07**/
public class Book {private String name;private double price;public Book(String name, double price) {this.name = name;this.price = price;}public String getName() {return name;}public double getPrice() {return price;}
}
  • 创建 Iterator 接口
/*** @author hanson.huang* @version V1.0* @InterfaceName Iterator* @Description 迭代器接口* @date 2025/3/25 19:09**/
public interface Iterator {boolean hasNext();Book next();
}
  • 创建 Aggregate 接口
/*** @author hanson.huang* @version V1.0* @InterfaceName Aggregate* @Description 聚合接口* @date 2025/3/25 19:10**/
public interface Aggregate {Iterator createIterator();
}
  • 创建 BookAggregate 具体聚合类
/*** @author hanson.huang* @version V1.0* @ClassName BookAggregate* @Description 具体聚合类 - 书籍集合* @date 2025/3/25 19:10**/
public class BookAggregate implements Aggregate {private List<Book> list = new ArrayList<>();public void add(Book book) {list.add(book);}public Book get(int index) {return list.get(index);}public int getSize() {return list.size();}@Overridepublic Iterator createIterator() {return new BookIterator(this);}
}
  • 创建 BookIterator 具体迭代器
/*** @author hanson.huang* @version V1.0* @ClassName BookIterator* @Description 具体迭代器* @date 2025/3/25 19:12**/
public class BookIterator implements Iterator {private int index;private BookAggregate bookAggregate;public BookIterator(BookAggregate bookAggregate) {this.index = 0;this.bookAggregate = bookAggregate;}@Overridepublic boolean hasNext() {return index < bookAggregate.getSize();}@Overridepublic Book next() {Book book = bookAggregate.get(index);index++;return book;}
}
  • 测试迭代器模式
/*** @author hanson.huang* @version V1.0* @ClassName IteratorPattern* @Description 测试迭代器模式* @date 2025/3/25 19:13**/
public class IteratorPattern {public static void main(String[] args) {BookAggregate bookAggregate = new BookAggregate();String[] books = {"数据结构", "操作系统", "计算机网络", "计算机组成原理"};double[] prices = {10.24, 20.48, 40.96, 81.92};for (int i = 0; i < books.length; i++) {bookAggregate.add(new Book(books[i], prices[i]));}Iterator iterator = bookAggregate.createIterator();while (iterator.hasNext()) {Book book = (Book) iterator.next();System.out.println(book.getName() + " " + book.getPrice());}}
}

📌 运行结果

在这里插入图片描述

🚩代码总结

  • Book 类表示聚合中的元素

  • Iterator 接口定义遍历操作

  • Aggregate 接口定义创建迭代器的方法

  • BookAggregate 是具体聚合类,管理Book对象的集合

  • BookIterator 是具体迭代器,实现遍历逻辑

  • IteratorPattern 客户端使用迭代器遍历聚合对象

🚩总结

  • 迭代器设计模式 提供了一种方法顺序访问聚合对象中的元素

  • 核心是 将遍历行为从聚合对象中分离出来,使两者可以独立变化

  • 适用于 需要遍历集合对象而又不暴露其内部结构 的场景

✅ Java源码中的应用场景:

  • Java集合框架

    • java.util.Iterator 接口

    • 所有集合类都实现了迭代器模式

创作不易,不妨点赞、收藏、关注支持一下,各位的支持就是我创作的最大动力❤️

在这里插入图片描述

相关文章:

23中设计模式-迭代器(Iterator)设计模式

迭代器设计模式 &#x1f6a9;什么是迭代器设计模式&#xff1f;&#x1f6a9;迭代器设计模式的特点&#x1f6a9;迭代器设计模式的结构&#x1f6a9;迭代器设计模式的优缺点&#x1f6a9;迭代器设计模式的Java实现&#x1f6a9;代码总结&#x1f6a9;总结 &#x1f6a9;什么是…...

Word中公式自动标号带章节编号

&#xff08;1&#xff09;插入一行三列的表格&#xff0c;设置宽度分别为0.5&#xff0c;13.39和1.5&#xff0c;设置纵向居中&#xff0c;中间列居中对齐&#xff0c;最右侧列靠右对齐&#xff0c;设置段落如下 &#xff08;2&#xff09;插入域代码 【Word】利用域代码快速实…...

基于动态 FOF(基金中的基金)策略的基金交易推荐系统的设计与实现思路

下面为你呈现一个基于动态 FOF&#xff08;基金中的基金&#xff09;策略的基金交易推荐系统的设计与实现思路&#xff0c;同时给出一个简单的 Python 示例代码。 系统设计 1. 需求分析 收集各类基金的历史数据&#xff0c;涵盖净值、收益率、风险指标等。依据动态 FOF 策略…...

【Spring AI】基于专属知识库的RAG智能问答小程序开发——功能优化:用户鉴权主体功能开发

系列文章目录 【Spring AI】基于专属知识库的RAG智能问答小程序开发——完整项目&#xff08;含完整前端后端代码&#xff09;【Spring AI】基于专属知识库的RAG智能问答小程序开发——代码逐行精讲&#xff1a;核心ChatClient对象相关构造函数【Spring AI】基于专属知识库的R…...

[7-01-03].SpringBoot3集成MinIo

MinIO学习大纲 一、Spingboot整合MinIo 第1步&#xff1a;搭建SpringBoot项目&#xff1a; 第2步&#xff1a;引入minio依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi&q…...

ISIS-3 LSDB链路状态数据库同步

上一章我们介绍了ISIS的邻居建立关系以及ISIS的路由器角色有哪些,在不同的网络类型当中建立邻居关系有什么不同,并且以实验案例抓包的形式给大家进一步介绍了建立的过程。 这一章我们来介绍ISIS中是如何实现链路状态数据库同步的,与OSPF的链路状态同步有什么不同,在不同网络类…...

快速入手-基于Django的Form和ModelForm操作(七)

1、Form组件 2、ModelForm操作 3、给前端表单里在django里添加class相关属性值 4、前端 5、后端form 新增数据处理 6、更新数据处理...

Springboot集成Debezium监听postgresql变更

1.创建springboot项目引入pom <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>io.debezium</groupI…...

Ubuntu22.04搭建freeradius操作说明

Ubuntu22.04搭建freeradius操作说明 更新依赖库 sudo apt update sudo apt install build-essential sudo apt install libtalloc-dev sudo apt install libssl-dev 按照freeradius sudo apt install freeradius 修改freeradius配置 文件路径如下 /etc/freeradius/3.…...

【重装系统】全流程记录,在 MacOS 的电脑上烧录 Ubuntu 启动盘

背景 Ubuntu 无法联网&#xff0c;排查下来应该是网卡驱动的问题&#xff0c;安装驱动的过程中又缺失各种包需要网络&#xff0c;陷入死循环。 全流程以及相关资料 整体流程参考&#xff1a;【史上最全】重装ubuntu20.04系统基本环境配置 烧录启动盘启动盘插入需要重装的服务…...

去中心化金融

什么是去中心化金融 去中心化金融&#xff08;Decentralized Finance&#xff0c;简称 DeFi&#xff09;是一种基于区块链技术构建的金融系统&#xff0c;旨在通过去除传统金融机构&#xff08;如银行、证券公司等&#xff09;作为中介&#xff0c;提供各种金融服务。这些服务…...

centos 7 部署FTP 服务用shell 脚本搭建

#!/bin/bash# 检查是否以root身份运行脚本 if [ "$EUID" -ne 0 ]; thenecho "请以root身份运行此脚本。"exit 1 fi# 安装vsftpd yum install -y vsftpd# 启动vsftpd服务并设置开机自启 systemctl start vsftpd systemctl enable vsftpd# 配置防火墙以允许F…...

VMware启动虚拟机报“另一个程序已锁定文件的一部分,进程无法访问”

解决方案&#xff1a; 1&#xff09;定位到虚拟机磁盘目录&#xff0c;我这里是“E\VM_Disk\CactiEZ\”这个目录&#xff0c;每个人目录不一样&#xff0c;详见上图报错位置 2&#xff09;在这个目录中找到后缀名以“.lck”结尾的目录&#xff0c;将所有以 .lck 结尾的目录删…...

Python基础(正则表达式)

正则表达式使用 在 Python 中&#xff0c;使用 re 模块来处理正则表达式 re.match函数 import re print(re.match(www, www.baidu.com).span()) #.span()&#xff1a;获取匹配对象的起始和结束索引&#xff0c;以元组形式返回 print(re.match(com, www.baidu.com))line &q…...

CPU架构和微架构

CPU架构&#xff08;CPU Architecture&#xff09; CPU架构是指处理器的整体设计框架&#xff0c;定义了处理器的指令集、寄存器、内存管理方式等。它是处理器设计的顶层规范&#xff0c;决定了软件如何与硬件交互。 主要特点&#xff1a; 指令集架构&#xff08;ISA, Instr…...

基于Zookeeper的微服务配置管理与灰度发布实战指南

引言 在分布式系统中&#xff0c;服务注册与发现、配置管理以及平滑发布是保障系统高可用性的关键。Apache Zookeeper作为一款成熟的分布式协调服务&#xff0c;结合Spring Cloud生态&#xff0c;能够有效解决这些挑战。本文将深入探讨Zookeeper的核心配置参数、服务注册机制&…...

帕金森病致生活艰难,如何缓解心理负担?

你是否留意到身边有人手部不由自主地颤抖&#xff0c;且肢体变得僵硬&#xff0c;行动也愈发迟缓&#xff1f;这很可能是帕金森病的症状。帕金森病是一种常见的神经系统退行性疾病&#xff0c;多发生于中老年人。​ 静止性震颤往往是帕金森病的首发症状&#xff0c;患者在安静状…...

使用 fn_dblog手动恢复误操作的 update(单列数值型数据恢复)

使用 fn_dblog手动恢复误操作的 update&#xff08;单列数值型数据恢复&#xff09; 事由fn_dblogfn_dblog 列数据意义 事由 通常&#xff0c;我们在操作数据库的时候&#xff0c;很对 update 指令指定一个更新范围&#xff0c;比如指定更新某个ID的数据&#xff0c;指定某个类…...

ambiq apollo3 ADC实例程序注释

#include "am_mcu_apollo.h" // Apollo MCU 外设寄存器定义和HAL库 #include "am_bsp.h" // 板级支持包&#xff08;引脚定义、LED函数等&#xff09; #include "am_util.h" // 通用工具函数&#xff08;如printf重…...

[Windows] Edge浏览器_134.0.3124.83绿色便携增强版-集成官方Deepseek侧边栏

微软Edge浏览器 绿色便携增强版 长期更新 链接&#xff1a;https://pan.xunlei.com/s/VOMA-aVC_GPJiv-MzRS89lsVA1?pwdemxj# Edge浏览器_134.0.3124.83绿色便携增强版-集成官方Deepseek侧边栏...

Python大数据方向就业

一、基础必备技能 1. ​Python编程 ​核心语法&#xff1a;熟练掌握函数、面向对象、异常处理、文件操作等。​数据处理库&#xff1a;Pandas&#xff08;数据清洗、分析&#xff09;、NumPy&#xff08;数值计算&#xff09;、Matplotlib/Seaborn&#xff08;数据可视化&…...

从零构建大语言模型全栈开发指南:第二部分:模型架构设计与实现-2.2.3实战案例:在笔记本电脑上运行轻量级LLM

👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 实战案例:在笔记本电脑上运行轻量级LLM2.2.3 模型架构设计与实现1. 环境与工具准备1.1 硬件要求1.2 软件栈选择2. 轻量级模型架构设计2.1 模型参数配置2.2 关键技术优化3. 实战流程3.1 数据准备流程3.2…...

CAN基础知识学习二

一、控制器局域网总线&#xff08;CAN&#xff0c;Controller Area Network&#xff09;&#xff1b; 二、CAN FD 是CAN with Flexible Data rate的缩写&#xff0c;翻译为【可变速率的 CAN】 CAN-FD 采用了两种位速率&#xff1a;从控制场中的 BRS 位到 ACK 场之前&#xff08…...

新能源行业:卓越 UE/UI 设计,引领业务腾飞的新引擎

在全球积极推动可持续发展的大背景下&#xff0c;新能源行业蓬勃兴起&#xff0c;成为经济发展的新引擎。在这个充满机遇与挑战的赛道上&#xff0c;优秀的用户体验&#xff08;UE&#xff09;和用户界面&#xff08;UI&#xff09;设计正扮演着愈发关键的角色&#xff0c;它不…...

Webview详解(上)

第一阶段&#xff1a;基础入门 WebView基础概念 什么是Webview&#xff1f; WebView是一种用于在移动应用程序中展示网页内容的嵌入式浏览器组件。它允许开发者将网页内容直接加载到应用界面中&#xff0c;用户无需离开应用即可浏览网页。WebView 通常用于加载 HTML、CSS、J…...

Docker镜像相关命令(Day2)

文章目录 前言一、问题描述二、相关命令1.查看镜像2.搜索镜像3.拉取镜像4.删除镜像5.镜像的详细信息6.标记镜像 三、验证与总结 前言 Docker 是一个开源的容器化平台&#xff0c;它让开发者能够将应用及其依赖打包到一个标准化的单元&#xff08;容器&#xff09;中运行。在 D…...

C++值传递和引用传递

系列文章目录 值传递和引用传递是 C 中两种常见的参数传递方式&#xff0c;它们的主要区别在于函数内部对参数的操作是否会影响原始数据 C值传递和引用传递 系列文章目录1、值传递2、引用传递3 、常量引用传递4、值传递 vs 引用传递总结 1、值传递 值传递会复制传入的参数&…...

LangChain4J开源开发框架简介

目录 1.1、前言1.2、集成方式简单1.3、核心功能与优势1.4、两种调用方式1.5、链式调用示例代码1.6、AI服务调用示例代码1.7、典型使用场景1.8、总结 1.1、前言 LangChain4J 是一个专为 Java 开发者设计的开源框架&#xff0c;旨在简化大型语言模型&#xff08;LLMs&#xff09;…...

Qt图形视图框架在项目中的应用

一、基本概念 Qt 的图形视图框架&#xff08;Graphics View Framework&#xff09;提供了一套用于显示和管理2D图形对象的框架。它提供了一组类&#xff0c;这些类可以组合使用来构建用户界面、处理图形对象、实现缩放、平移、旋转等操作。以下是Qt GraphicsView框架的主要组件…...

SpringBoot集成Elasticsearch 7.x spring-boot-starter-data-elasticsearch 方式

SpringBoot集成Elasticsearch 7.x | spring-boot-starter-data-elasticsearch 方式 前言添加maven依赖配置application.properties测试实体类 方式一&#xff1a;继承 ElasticsearchRepository&#xff08;适合简单查询&#xff09; 直接使用想自定义自己的Repository接口 方式…...