迭代器模式
时间:2022-04-26
本文章向大家介绍迭代器模式,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
一、简介
1、迭代器模式提供一种方法顺序访问一个聚合对象中的各个元素,而又不暴露该对象的内部表示。
2、类成员
(1)Iterator(迭代器)迭代器定义访问和遍历元素的接口
(2)ConcreteIterator (具体迭代器)具体迭代器实现迭代器接口对该聚合遍历时跟踪当前位置
(3)Aggregate (聚合)聚合定义创建相应迭代器对象的接口
(4)ConcreteAggregate (具体聚合)具体聚合实现创建相应迭代器的接口,该操作返回ConcreteIterator的一个适当的实例
3、现在的高级语言如C#,JAVA等本身已经将这个模式做在语言中了,所以这里只是学习一下思路而已。
4、UML
5、所属类别:行为型
二、C++代码
1 // 迭代器模式.cpp : 定义控制台应用程序的入口点。
2 //
3
4 #include "stdafx.h"
5 #include<iostream>
6 #include<string>
7 #include<vector>
8 using namespace std;
9
10 class Iterator
11 {
12 public:
13 Iterator(){}
14 virtual ~Iterator(){}
15 virtual string first()=0;
16 virtual void next()=0;
17 virtual bool isdone()=0;
18 virtual string currentitem()=0;
19 };
20 class Aggregate
21 {
22 public:
23 Aggregate(){}
24 virtual ~Aggregate(){}
25 //virtual Iterator* createiterator()=0;
26 };
27
28 class ConcreteAggregate:public Aggregate
29 {
30 private:
31 vector<string>Vector;
32 public:
33 ConcreteAggregate(){}
34 virtual ~ConcreteAggregate(){}
35 int count()
36 {
37 return Vector.size();
38 }
39 void add(string s)
40 {
41 Vector.push_back(s);
42 }
43 string value(int index)
44 {
45 if (index<Vector.size())
46 {
47 return Vector[index];
48 }
49 }
50 };
51 class ConcreteIterator:public Iterator
52 {
53 private:
54 ConcreteAggregate * myConcreteAggregate;
55 int count;
56 public:
57 ConcreteIterator(ConcreteAggregate *c):myConcreteAggregate(c)
58 {
59 count=0;
60 }
61 virtual ~ConcreteIterator(){}
62 virtual string first()
63 {
64 count=0;
65 return myConcreteAggregate->value(0);
66 }
67 virtual void next()
68 {
69 if(count<myConcreteAggregate->count())
70 {
71 count++;
72 //return myConcreteAggregate->value(count);
73 }
74 }
75 virtual bool isdone()
76 {
77 return count<myConcreteAggregate->count() ? true : false;
78 }
79 virtual string currentitem()
80 {
81 return myConcreteAggregate->value(count);
82 }
83 };
84 int _tmain(int argc, _TCHAR* argv[])
85 {
86 ConcreteAggregate *c=new ConcreteAggregate();
87 c->add("hello");
88 c->add(" ");
89 c->add("world");
90 c->add("!");
91 ConcreteIterator *iter=new ConcreteIterator(c);
92 for(iter->first();iter->isdone();iter->next())
93 {
94 cout<<iter->currentitem();
95 }
96 return 0;
97 }
- 两个元素定位,要求子元素垂直居中
- 在Spring Boot框架下使用WebSocket实现消息推送
- Linux上安装Zookeeper以及一些注意事项
- Nginx+Tomcat搭建集群,Spring Session+Redis实现Session共享
- Shiro中的授权问题(二)
- Shiro中的授权问题
- Spring Cloud中服务的发现与消费
- 使用Spring Cloud搭建高可用服务注册中心
- 从Netflix的Hystrix框架理解服务熔断和服务降级
- 使用Spring Cloud搭建服务注册中心
- 技术分享 | kafka的使用场景以及生态系统
- WebSocket刨根问底(二)
- WebSocket刨根问底(三)之群聊
- SDNLAB群分享(四):利用ODL下发流表创建VxLAN网络
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- flink教程-flink modules详解之使用hive函数
- 面试iOS 机会在自己手中
- Flink教程-将流式数据写入redis
- Flink教程-keyby 窗口数据倾斜的优化
- Flink源码分析之深度解读流式数据写入hive
- 浙大版《C语言程序设计(第3版)》题目集 习题10-1 判断满足条件的三位数
- 差分标记-HDU1556 Color the ball
- flink cep 案例之机架温度监控报警
- 详解flink 1.11中的新部署模式-Application模式
- 浙大版《C语言程序设计(第3版)》题目集 习题10-2 递归求阶乘和
- hadoop源码解析之RPC分析
- 存储过程和触发器
- hadoop源码学习之namenode启动
- 浙大版《C语言程序设计(第3版)》题目集 习题10-3 递归实现指数函数
- hadoop2.7.3源码解析之datanode注册和心跳机制