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

Linux C++ 056-设计模式之迭代器模式

Linux C++ 056-设计模式之迭代器模式

本节关键字:Linux、C++、设计模式、迭代器模式
相关库函数:

概念

迭代器模式(Iterator Pattern)是一种常用的设计模式。迭代器模式提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露其内部的表示。迭代器模式属于行为型模式。

优缺点

优点

支持多种遍历方式:不同的迭代器可以定义不同的遍历方式。
简化聚合类:聚合类不需要关心遍历逻辑。
多遍历支持:可以同时对同一个聚合对象进行多次遍历。
扩展性:增加新的聚合类和迭代器类都很方便,无需修改现有代码。

缺点

系统复杂性:每增加一个聚合类,就需要增加一个对应的迭代器类,增加了类的数量。

使用场景

1、当需要遍历一个聚合对象,而又不希望暴露其内部结构时。

2、当需要访问聚合对象内容而不暴露其内部表示时,使用迭代器模式。

3、当需要为聚合对象提供多种遍历方式时,考虑使用迭代器模式。

4、为遍历不同的聚集结构提供如开始、下一个、是否结束、当前哪一项等统一的接口。

角色说明

迭代器模式包含以下几个主要角色:

迭代器接口(Iterator):定义了访问和遍历聚合对象中各个元素的方法,通常包括获取下一个元素、判断是否还有元素、获取当前位置等方法。

具体迭代器(Concrete Iterator):实现了迭代器接口,负责对聚合对象进行遍历和访问,同时记录遍历的当前位置。

聚合对象接口(Aggregate):定义了创建迭代器对象的接口,通常包括一个工厂方法用于创建迭代器对象。

具体聚合对象(Concrete Aggregate):实现了聚合对象接口,负责创建具体的迭代器对象,并提供需要遍历的数据。

示例代码

#include <iostream>
#include <vector>
#include <stdexcept>// 迭代器接口
class Iterator 
{
public:virtual int next() = 0;virtual bool hasNext() = 0;
};// 具体迭代器
class ConcreteIterator : public Iterator 
{
private:std::vector<int> data;size_t position;public:ConcreteIterator(const std::vector<int>& data) : data(data), position(0) {}int next() override {if (hasNext()) {return data[position++];} else {throw std::out_of_range("No more elements");}}bool hasNext() override {return position < data.size();}
};// 聚合接口
class Aggregate 
{
public:virtual Iterator* createIterator() = 0;
};// 具体聚合
class ConcreteAggregate : public Aggregate 
{
private:std::vector<int> data;public:ConcreteAggregate(const std::vector<int>& data) : data(data) {}Iterator* createIterator() override {return new ConcreteIterator(data);}
};int main(int argc, char *argv[])
{std::vector<int> data = {1, 2, 3, 4, 5};// 使用迭代器遍历聚合对象Aggregate* aggregate = new ConcreteAggregate(data);Iterator* iterator = aggregate->createIterator();while (iterator->hasNext()) {std::cout << iterator->next() << " ";}std::cout << "\n";delete iterator;delete aggregate;return 0;
}
http://www.lryc.cn/news/402268.html

相关文章:

  • 【Elasticsearch7.11】reindex问题
  • nginx代理缓存
  • [React 进阶系列] useSyncExternalStore hook
  • Linux C++ 055-设计模式之状态模式
  • 景联文科技构建高质量心理学系知识图谱,助力大模型成为心理学科专家
  • 【数学建模】——数学规划模型
  • 卸载linux 磁盘的内容,磁盘占满
  • LeetCode-随机链表的复制
  • axios 下载大文件时,展示下载进度的组件封装——js技能提升
  • Linux: network: device事件注册机制 chatGPT; notify
  • 【ROS2】测试
  • 别卷模型,卷应用:从李彦宏的AI观点谈起
  • 数据库(Database,简称DB)介绍
  • Redis五种常用数据类型详解及使用场景
  • Postman API测试覆盖率:全面评估指南
  • C++--find
  • JavaWeb入门程序解析(Spring官方骨架、配置起步依赖、SpringBoot父工程、内嵌Tomcat)
  • mysql命令练习
  • AI绘画Stable Diffusion 零基础入门 —AI 绘画原理与工具介绍,万字解析AI绘画的使用教程
  • jenkins添加ssh证书
  • C++--accumulate介绍
  • C++写一个线程池
  • 【SASS/SCSS(一)】选择器
  • 详细解析Kafaka Streams中各个DSL操作符的用法
  • C++中链表的底层迭代器实现
  • 3.5、matlab打开显示保存点云文件(.ply/.pcd)以及经典点云模型数据
  • Qt-事件与信号
  • 数据结构 day3
  • Kubernetes面试整理-如何进行滚动更新和回滚?
  • flutter ios打包 xcode报错module ‘xxx‘ not found