C++设计模式浅识迭代器模式
迭代器模式:提供一中方法顺序访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示。【DP】
四个角色:
Iterator迭代器抽象类: 用于定义得到开始对象,得到下一个对象、判断是否到结尾、当前对象等抽象方法,统一接口。
ConcreteIterator具体迭代器类: 继承Iterator,实现具体开始对象、下一个对象等方法。
Aggregate聚集抽象类: 创建迭代器
ConcreteAggregate具体聚集类
适用场合:
当你需要访问一个聚集对象,而且不管这些对象是什么,只需要遍历的时候。
需要对聚集有多种方式遍历时,如从前至后或从后至前。
为遍历不同的聚集结构提供如开始、下一个、是否结束、当前哪一项等统一的结构。
测试用例:
[code]int main(){ ConcreteAggregate pa; pa.Add("BigBird"); pa.Add("Pickles"); pa.Add("Luggage"); pa.Add("Foreigners"); pa.Add("InnerStaff"); pa.Add("Thief"); ConcreteIterator Itr(pa); string temp = Itr.First(); while (!Itr.IsDone()) { std::cout << Itr.currentItem() << ", ticket, Please\n"; Itr.Next(); } return 0; }
迭代器模式实现:
[code]//迭代器模式 #include <iostream> #include <deque> #include <string> using std::string; using std::deque; //MyIterator迭代器抽象类 class MyIterator{ public: MyIterator(){} //得到开始对象 virtual string First() = 0; //得到下一个对象 virtual string Next() = 0; //判断是否到结尾 virtual bool IsDone() = 0; //当前对象 virtual string currentItem() = 0; }; //抽象聚集类 class Aggregate{ public: Aggregate(){} //创建迭代器 virtual MyIterator* createIterator() = 0; private: friend class MyIterator; }; //具体聚集类 class ConcreteAggregate: public Aggregate{ public: MyIterator* createIterator(); int Count(); void Add(string st); string This(int index); private: friend class ConcreteIterator; //乘客队列 deque<string> passengers; }; //具体的迭代器类 class ConcreteIterator: public MyIterator{ public: ConcreteIterator(ConcreteAggregate); string First(); string Next(); bool IsDone(); string currentItem(); private: //以具体的聚集类为友元类 friend class ConcreteAggregate; ConcreteAggregate aggregate; int current = 0; }; //方法实现 //具体迭代器类 ConcreteIterator::ConcreteIterator(ConcreteAggregate cAgg): aggregate(cAgg), current(cAgg.passengers.size() - 1){ } string ConcreteIterator::First(){ return aggregate.This(0); } string ConcreteIterator::Next(){ string temp; --current; if(current >= 0) temp = aggregate.This(current); return temp; } string ConcreteIterator::currentItem(){ return aggregate.This(current); } bool ConcreteIterator::IsDone(){ return current >= 0 ? false : true; } //方法实现 //具体聚集类 MyIterator* ConcreteAggregate::createIterator(){ return (new ConcreteIterator(*this)); } int ConcreteAggregate::Count(){ return passengers.size(); } void ConcreteAggregate::Add(string st){ passengers.push_back(st); } string ConcreteAggregate::This(int index){ return passengers.at(index); }
总结:迭代器模式就是分离了集合对象的遍历行为,抽象出一个迭代器类来负责,这样既可以做到不暴露集合内部结构,又可让外部代码透明地访问集合内部的数据。
以上就是C++设计模式浅识迭代器模式的内容,更多相关内容请关注PHP中文网(www.php.cn)!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

在 C 语言中,char 类型在字符串中用于:1. 存储单个字符;2. 使用数组表示字符串并以 null 终止符结束;3. 通过字符串操作函数进行操作;4. 从键盘读取或输出字符串。

在Docker环境中使用PECL安装扩展时报错的原因及解决方法在使用Docker环境时,我们常常会遇到一些令人头疼的问�...

C35 的计算本质上是组合数学,代表从 5 个元素中选择 3 个的组合数,其计算公式为 C53 = 5! / (3! * 2!),可通过循环避免直接计算阶乘以提高效率和避免溢出。另外,理解组合的本质和掌握高效的计算方法对于解决概率统计、密码学、算法设计等领域的许多问题至关重要。

语言多线程可以大大提升程序效率,C 语言中多线程的实现方式主要有四种:创建独立进程:创建多个独立运行的进程,每个进程拥有自己的内存空间。伪多线程:在一个进程中创建多个执行流,这些执行流共享同一内存空间,并交替执行。多线程库:使用pthreads等多线程库创建和管理线程,提供了丰富的线程操作函数。协程:一种轻量级的多线程实现,将任务划分成小的子任务,轮流执行。

std::unique 去除容器中的相邻重复元素,并将它们移到末尾,返回指向第一个重复元素的迭代器。std::distance 计算两个迭代器之间的距离,即它们指向的元素个数。这两个函数对于优化代码和提升效率很有用,但也需要注意一些陷阱,例如:std::unique 只处理相邻的重复元素。std::distance 在处理非随机访问迭代器时效率较低。通过掌握这些特性和最佳实践,你可以充分发挥这两个函数的威力。

C语言中蛇形命名法是一种编码风格约定,使用下划线连接多个单词构成变量名或函数名,以增强可读性。尽管它不会影响编译和运行,但冗长的命名、IDE支持问题和历史包袱需要考虑。

C 中 release_semaphore 函数用于释放已获得的信号量,以便其他线程或进程访问共享资源。它将信号量计数增加 1,允许阻塞的线程继续执行。

探索C语言编程的未定义行为:一本详尽指南本文介绍一本关于C语言编程中未定义行为的电子书,共12章,涵盖了C语言编程中一些最棘手和鲜为人知的方面。本书并非C语言入门教材,而是面向熟悉C语言编程的读者,深入探讨未定义行为的各种情况及其潜在后果。作者DmitrySviridkin,编辑AndreyKarpov。历经六个月的精心准备,这本电子书终于与读者见面。未来还将推出印刷版。本书最初计划包含11章,但在创作过程中,内容不断丰富,最终扩展到12章——这本身就是一个经典的数组越界案例,可谓是每个C程序员
