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

迭代器模式(Iterator Pattern)

定义

迭代器模式(Iterator Pattern)是一种行为型设计模式,它提供了一种方法来顺序访问聚合对象中的各个元素,而不需要暴露该对象的内部表示。迭代器模式使得客户端代码能够独立于聚合对象的具体实现进行遍历操作。

在迭代器模式中,我们定义以下几个角色:

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

  2. ConcreteIterator(具体迭代器):实现迭代器接口,并记录遍历的当前位置。

  3. Aggregate(聚合):定义创建迭代器对象的接口。

  4. ConcreteAggregate(具体聚合):实现创建迭代器对象的接口,返回具体迭代器的实例。

示例

下面是一个C++中使用迭代器模式的示例,我们创建一个简单的集合类(整数数组),并为其提供一个迭代器:

#include <iostream>  
#include <vector>  // 迭代器接口  
class Iterator {  
public:  virtual bool hasNext() const = 0; // 检查是否还有下一个元素  virtual int next() = 0;           // 返回下一个元素,并将位置向前移动  
};  // 具体迭代器实现  
class IntIterator : public Iterator {  
private:  std::vector<int>::const_iterator it;  public:  IntIterator(std::vector<int>::const_iterator it) : it(it) {}  bool hasNext() const override {  return it != std::end(container);  }  int next() override {  return *it++;  }  private:  static std::vector<int> container; // 存储元素的容器,这里使用静态成员简化示例  
};  std::vector<int> IntIterator::container = {1, 2, 3, 4, 5}; // 初始化静态成员  // 聚合接口  
class Aggregate {  
public:  virtual Iterator* createIterator() = 0; // 创建迭代器对象  
};  // 具体聚合实现  
class IntAggregate : public Aggregate {  
public:  Iterator* createIterator() override {  return new IntIterator(std::begin(IntIterator::container)); // 返回具体迭代器实例  }  
};  // 客户端代码  
int main() {  Aggregate* aggregate = new IntAggregate(); // 创建具体聚合对象  Iterator* iterator = aggregate->createIterator(); // 获取迭代器  while (iterator->hasNext()) {  std::cout << iterator->next() << " "; // 使用迭代器遍历元素  }  delete iterator; // 释放迭代器  delete aggregate; // 释放聚合对象  return 0;  
}

在这个示例中,我们定义了一个迭代器接口 Iterator 和一个具体迭代器实现 IntIteratorIntIterator 通过 std::vector<int>::const_iterator 来实现遍历整数数组的功能。我们还定义了一个聚合接口 Aggregate 和一个具体聚合实现 IntAggregate,它负责创建迭代器对象。

客户端代码通过调用 Aggregate 的 createIterator 方法来获取迭代器,并使用迭代器来遍历聚合对象中的元素。这样,客户端代码就可以在不了解聚合对象内部实现的情况下进行遍历操作。

迭代器模式的主要优点有:

  1. 支持多种遍历方式:客户端代码可以使用不同的迭代器来遍历同一个聚合对象,实现多种遍历方式。

  2. 封装聚合的内部表示:迭代器模式将聚合对象的内部表示与遍历操作分离,隐藏了聚合对象的内部细节。

  3. 增加新的聚合类和迭代器类容易:由于客户端代码是通过迭代器接口与聚合对象交互的,因此增加新的聚合类和迭代器类不会对客户端代码产生影响。

需要注意的是,在实际应用中,聚合对象可能包含大量的元素,因此迭代器的实现需要考虑到性能问题。此外,为了避免内存泄漏,需要正确地管理迭代器和聚合对象的生命周期。

相关文章:

迭代器模式(Iterator Pattern)

定义 迭代器模式&#xff08;Iterator Pattern&#xff09;是一种行为型设计模式&#xff0c;它提供了一种方法来顺序访问聚合对象中的各个元素&#xff0c;而不需要暴露该对象的内部表示。迭代器模式使得客户端代码能够独立于聚合对象的具体实现进行遍历操作。 在迭代器模式…...

KL divergence(KL 散度)详解

本文用一种浅显易懂的方式说明KL散度。 参考资料 KL散度本质上是比较两个分布的相似程度。 现在给出2个简单的离散分布&#xff0c;称为分布1和分布2. 分布1有3个样本&#xff0c; 其中A的概率为50%, B的概率为40%&#xff0c;C的概率为10% 分布2也有3个样本&#xff1a; 其…...

AzerothCore@FreeBSD安装记录

尝试在FreeBSD系统下安装AzerothCore 首先安装相关软件 pkg install cmake mysql80-server boost-all装完mysql之后提示&#xff1a; MySQL80 has a default /usr/local/etc/mysql/my.cnf, remember to replace it with your own or set mysql_optfile"$YOUR_CNF_FILE i…...

vue .env配置环境变量

最近使用的不同的环境有点多了&#xff0c;接口文件ip一直在替换打包&#xff0c;看了下文档&#xff0c;有个方案使用.env配置不同的环境运行打包 vue 现在已经兼容了env &#xff0c;无需下载 创建文件&#xff08;根目录&#xff09; 创建.env.development&#xff0c;.env.…...

ThreadLocal介绍

文章目录 ThreadLocal源码分析&#xff1a;set方法get方法remove方法 ThreadLocal内存泄漏问题 ThreadLocal ThreadLocal提供了线程局部变量&#xff0c;每个线程都可以通过set和get方法来对这个变量进行操作&#xff0c;但不会和其他线程的局部变量冲突&#xff0c;实现了线程…...

【Linux系统化学习】线程概念

目录 线程的概念 线程的引出 什么是线程 理解线程比进程更加的轻量化 线程的优点 现成的缺点 线程异常 线程用途 Linux进程VS线程 线程的简单现象 线程的概念 有关操作系统的书籍或者课本都会这样描述线程&#xff1a; 线程是比进程轻量化的一种执行流线程是进程内部…...

Redis集群模式

分片 面试题&#xff1a;为什么Redis的最大槽位是16384&#xff1f; 翻译一下作者的话&#xff1a; 解读一下&#xff1a;...

执行go get xxx报错

1、执行命令 go get github.com/go-redis/redis/v8 报错 &#xff1a; go: coding.jd.com/xxx/xxxxxxv0.0.0-xxxxxxxxxx: invalid version: git ls-remote -q origin in /users/douhao7/go/pkg/mod/cache/vcs/xxxxxxxxxxxxxx: exit status 128: 致命错误:could not read use…...

MATLAB基础语法与实践

文章目录 初级篇MATLAB简介特点 安装和配置界面介绍 中级篇基础语法变量表达式函数 数据类型整数和浮点数复数字符串单元数组 高级篇脚本与函数编写脚本编写函数编写 图形绘制数据分析 实践篇实例演示1&#xff1a;矩阵运算实例演示2&#xff1a;数据可视化 初级篇 MATLAB简介…...

智能边缘小站 CloudPond(低延迟、高带宽和更好的数据隐私保护)

智能边缘小站 CloudPond(低延迟、高带宽和更好的数据隐私保护) 边缘小站的主要功能是管理用户在线下部署的整机柜设施&#xff0c;一个边缘小站关联一个华为云指定的区域和一个用户指定的场地&#xff0c;相关的资源运行状况监控等。 边缘计算 迈入5G和AI时代&#xff0c;新…...

回归预测 | Matlab实现RIME-BP霜冰算法优化BP神经网络多变量回归预测

回归预测 | Matlab实现RIME-BP霜冰算法优化BP神经网络多变量回归预测 目录 回归预测 | Matlab实现RIME-BP霜冰算法优化BP神经网络多变量回归预测预测效果基本描述程序设计参考资料 预测效果 基本描述 1.Matlab实现RIME-BP霜冰算法优化BP神经网络多变量回归预测&#xff08;完整…...

LeetCode15:三数之和

题目描述 给你一个整数数组 nums &#xff0c;判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k &#xff0c;同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 注意&#xff1a;答案中不可以包含重复的三元组…...

【详识JAVA语言】面向对象程序三大特性之三:多态

多态 多态的概念 多态的概念&#xff1a;通俗来说&#xff0c;就是多种形态&#xff0c;具体点就是去完成某个行为&#xff0c;当不同的对象去完成时会产生出不同的状态。 多态实现条件 在java中要实现多态&#xff0c;必须要满足如下几个条件&#xff0c;缺一不可&#xf…...

nginx(三)实现反向代理客户端 IP透传

正常情况下&#xff0c;客户端去访问代理服务器&#xff0c;然后代理服务器再取访问真实服务器&#xff0c;在真实服务器上&#xff0c;只能显示代理服务器的ip地址&#xff0c;而不显示客户端的ip地址&#xff0c;如果想让客户端的ip地址也能在真实服务端看见&#xff0c;这一…...

深入Java日志框架及其最佳实践

概述 在Java应用开发中&#xff0c;日志框架是确保应用稳定性和可观察性的关键组件。它帮助开发者记录应用的行为、诊断问题&#xff0c;并监控系统的健康状况。随着Java生态系统的不断发展&#xff0c;各种日志框架也应运而生&#xff0c;各有特点和优势。本文将详细探讨几个…...

threejs显示本地硬盘上的ply文件,通过webapi

由于ply文件是第三方提供的&#xff0c;threejs无法用绝路路径的方式显示ply 所以想通过webapi把ply通过url地址的方式给threejs 1.webapi部分 /// <summary>/// 获取PLY文件/// </summary>/// <returns></returns>[HttpPost(Name "GetPly&qu…...

代码随想录day10(2)字符串:反转字符串Ⅱ (leetcode541)

题目要求&#xff1a;给定一个字符串 s 和一个整数 k&#xff0c;从字符串开头算起, 每计数至 2k 个字符&#xff0c;就反转这 2k 个字符中的前 k 个字符。如果剩余字符少于 k 个&#xff0c;则将剩余字符全部反转。如果剩余字符小于 2k 但大于或等于 k 个&#xff0c;则反转前…...

【MySQL】_联合查询基础表

联合查询也称为多表查询&#xff0c;是将多个表联合到一起进行查询&#xff1b; 笛卡尔积是联合查询的基础&#xff0c;笛卡尔积其实就是一种排列组合&#xff0c;把两张表的记录尽可能地排列组合出n种情况&#xff1a; 以两张表&#xff1a;班级表与学生表为例&#xff0c;计…...

InnoDB存储引擎对MVCC的实现

MVCC MVCC的目的 在搞清楚MVCC之前,我们要搞懂一个问题,MVCC到底解决的是什么问题? 我用一句话概括,那就是为了解决读-写可以一起的问题! 在我们的印象里,InnoDB可以读读并发,不能读写并发,或者写写并发 这是很正常的想法,因为如果读写并发的化,会有并发问题 而对于写写…...

【精选】Java项目介绍和界面搭建——拼图小游戏 中

&#x1f36c; 博主介绍&#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 hacker-routing &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【应急响应】 【Java】 【VulnHub靶场复现】【面试分析】 &#x1f389;点赞➕评论➕收藏 …...

技术人的职业规划:打造成功的职业生涯

技术人的职业规划&#xff1a;打造成功的职业生涯 引言 作为一名技术人&#xff0c;职业规划是实现职业目标的关键。在快速变化的技术领域&#xff0c;一个清晰的职业规划可以帮助我们明确方向&#xff0c;抓住机会&#xff0c;实现个人价值。 回顾我的职业历程&#xff0c;从一…...

CSS背景效果完全指南

CSS背景效果完全指南 引言 CSS背景效果是美化网页的重要手段&#xff0c;通过合理使用背景属性&#xff0c;可以创造出丰富的视觉效果。本文将深入探讨CSS背景的各种属性和高级技巧。 一、背景基础 1.1 background-color .element {background-color: #4CAF50;background-color…...

通过Hermes Agent对接Taotoken自定义模型提供方

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 通过Hermes Agent对接Taotoken自定义模型提供方 Hermes Agent是一个流行的AI Agent开发框架&#xff0c;它支持通过统一的接口调用…...

AI写作辅助平台8款AI写作辅助软件梯队榜,毕业护航!

论文选题毫无头绪&#xff0c;文献检索耗时费力&#xff0c;格式排版反复修改&#xff1f; 查重率居高不下&#xff0c;写作思路始终不畅&#xff0c;时间紧迫却无从下手&#xff1f; 面对繁杂的学术任务&#xff0c;你是否也感到力不从心&#xff1f; 别担心&#xff01;AI论文…...

卖切削液怎么找客户?下游工厂在哪里

卖切削液找客户&#xff0c;本质是找用切削液的下游工厂&#xff0c;核心难点是拿到这些下游厂的名单和联系人。切削液不像消费品&#xff0c;它的消耗量和工厂的机床数量、加工班次直接挂钩——有金属切削车间的工厂才是真客户&#xff0c;没有机加工产线的工厂对你毫无意义。…...

ChatGPT写不出合格投资人邮件?错!真正稀缺的是这5个私募股权语境理解层(附LP偏好词云图谱)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;ChatGPT投资人邮件撰写的核心误区与范式跃迁 许多创业者在使用ChatGPT辅助撰写面向投资人的邮件时&#xff0c;陷入“信息堆砌型”表达陷阱——将产品功能、技术参数、市场数据不加筛选地塞入正文&…...

明日方舟桌宠Ark-Pets显卡优化配置指南:3步实现流畅桌面动画

明日方舟桌宠Ark-Pets显卡优化配置指南&#xff1a;3步实现流畅桌面动画 【免费下载链接】Ark-Pets Arknights Desktop Pets | 明日方舟桌宠 (ArkPets) 项目地址: https://gitcode.com/gh_mirrors/ar/Ark-Pets Ark-Pets是一款基于《明日方舟》角色模型的桌面宠物软件&am…...

Google 广告场景下 Uniswap 钓鱼攻击机理与 Web3 防御体系研究

摘要 2026 年 5 月 22 日&#xff0c;GoPlus 安全团队发布预警&#xff0c;针对 Web3 领域头部去中心化交易平台 Uniswap 的搜索引擎钓鱼攻击呈规模化爆发态势。攻击者通过购买 Google Ads 关键词广告&#xff0c;将高仿钓鱼网站置顶于搜索结果前列&#xff0c;结合视觉相似域名…...

自动化图表:用 AI 指令将测试执行结果秒变炫酷的 Excel 漏斗图/折线图

友情提示:文末有「选型对照表 + 安全自查清单」,如果你正在选 AI 出图方案,可以直接跳到文末。 一、从一张测试报告说起 如果你是测试工程师或项目管理者,下面这个场景你一定不陌生: 每周五下午,你需要把本周的测试执行结果整理成图表——通过率趋势、模块缺陷分布、用…...

ASP.NET ViewState反序列化漏洞原理与防御实战

1. 这不是“又一个反序列化漏洞”&#xff0c;而是ASP.NET框架层的定时炸弹你有没有遇到过这样的情况&#xff1a;一个看似普通的ASP.NET WebForms站点&#xff0c;登录页用的是标准的Login控件&#xff0c;后台管理界面用的是GridView和DetailsView&#xff0c;一切看起来都那…...