C++泛型编程(1)--自己实现C++迭代器/遍历器 iterator
1.原理
迭代器又称为遍历器,用于访问容器中的数据,迭代器旨在算法和容器之间搭建访问的桥梁,从而使算法和数据分离,不用关心数据具体的存储细节。具体的原理描述请参考以下两个博客:
[1].C++迭代器 iterator
[2].Iterator模式C++实现
迭代器的UML图:

(来自:http://www.cnblogs.com/yc_sunniwell/archive/2010/06/25/1764934.html)
2.实现
根据以上的原理图,下面实现一个简单的迭代器。
/*
* 以下实现了一个容器的迭代器(访问器)
*/
#include <boost/assert.hpp>
#include <iostream>
using namespace std; // 迭代器基类
template<typename T>
class Iterater {
public:
virtual ~Iterater() {
}
virtual void first() = ;
virtual void next() = ;
virtual bool isDone() = ;
virtual T currentItem() = ;
}; // 容器基类
template<typename T>
class Aggregate {
public:
virtual ~Aggregate() {
}
virtual Iterater<T>* createIterater() = ;
virtual int getSize() = ;
virtual T getItem(int nIndex) = ;
}; // 具体迭代器
template<typename T>
class ConcreateIterater : public Iterater<T> {
private:
Aggregate<T>* p_;
int cur_index_; public:
ConcreateIterater(Aggregate<T>* agregate)
: cur_index_(),
p_(agregate) {
} ~ConcreateIterater() {
} void first() {
cur_index_ = ;
} void next() {
if (cur_index_ < p_->getSize()) {
cur_index_++;
}
} bool isDone() {
if (cur_index_ > p_->getSize() - ) {
return true;
}
return false;
} T currentItem() {
return p_->getItem(cur_index_);
}
}; // 具体迭代器
template<typename T>
class ConcreateAggregate : public Aggregate<T> {
public:
ConcreateAggregate(int nSize)
: size_(nSize),
data_(NULL) {
data_ = new T[nSize];
for (int i = ; i < nSize; i++) {
data_[i] = i;
}
} Iterater<T>* createIterater() {
return new ConcreateIterater<T>(this);
} int getSize() {
return size_;
} T getItem(int nIndex) {
if (nIndex < || nIndex >= size_)
return (T) (-);
return data_[nIndex];
}
public:
int size_;
T* data_;
}; int main(int argc, char** argv) {
Aggregate<double>* pag = new ConcreateAggregate<double>();
Iterater<double>* pcon = pag->createIterater(); // 1 of 2
//cxk::Iterater<int>* pcon = new cxk::ConcreateIterater<int>(pag); // 2 of 2
cout << "all value:" << endl;
for (pcon->first(); !pcon->isDone(); pcon->next()) {
cout << "value:" << pcon->currentItem() << endl;
} return ;
}
3.结果
all value:
value:
value:
value:
value:
value:
value:
value:
value:
value:
value:
all value:value:0value:1value:2value:3value:4value:5value:6value:7value:8value:9
C++泛型编程(1)--自己实现C++迭代器/遍历器 iterator的更多相关文章
- Java List中迭代器遍历
在java中,List接口从Collection接口中继承了 iterator()函数,返回值是一个T类型的迭代器(泛型),T是List中元素的类型 public class TestListAndI ...
- java 迭代器遍历List Set Map
Iterator接口: 所有实现了Collection接口的容器类都有一个iterator方法用以返回一个实现Iterator接口的对象 Iterator对象称作为迭代器,用以方便的对容器内元素的遍历 ...
- Iterator、for..of,for...in和自定义遍历器**
Iterator.for..of,for...in和自定义遍历器 Iterator: var arr = [1,2,3,4,5]; var ite = arr[Symbol.iterator](); ...
- ES6的 Iterator 遍历器到底是什么?
这节课要讲的是ES6中的Iterator. for...of为啥不遍历Object对象 第十三节我们讲了简单又实用的for...of,我们可以使用它来遍历数组,字符串,Set和Map结构,但是有没有发 ...
- Java基础知识强化之集合框架笔记07:Collection集合的遍历之迭代器遍历
1. Collection的迭代器: Iterator iterator():迭代器,集合的专用遍历方式 2. 代码示例: package cn.itcast_03; import java.util ...
- Redis Scan迭代器遍历操作原理(一)
Redis在2.8.0版本新增了众望所归的scan操作,从此再也不用担心敲入了keys*, 然后举起双手看着键盘等待漫长的系统卡死了··· 命令的官方介绍在这里, 中文版由huangz同学细心翻译了, ...
- Redis Scan迭代器遍历操作原理(二)
续上一篇文章 Redis Scan迭代器遍历操作原理(一)–基础 ,这里着重讲一下dictScan函数的原理,其实也就是redis SCAN操作最有价值(也是最难懂的部分). 关于这个算法的源头,来自 ...
- Java 中List 集合索引遍历与迭代器遍历
package yzhou.iterator; import java.util.ArrayList; import java.util.HashSet; import java.util.Itera ...
- 有关map中使用iterate迭代器遍历的不保序问题和list remove(object)的细节问题
今天在做项目的过程中发现了如下两个问题: 一 使用map的iterator迭代器对map进行遍历得到的结果是不保序的,也就是每次输出结果都是不一样的.针对这个问题,看以下iterator迭代器的源码. ...
随机推荐
- vi与vim
vi 的使用 基本上 vi 共分为三种模式,分别是『一般模式』.『编辑模式』与『指令列命令模式』. 这三种模式的作用分别是: 一般模式:以 vi 打开一个档案就直接进入一般模式了(这是默认的模式).在 ...
- centos6.5下java和tomcat环境部署
软件包: tomcat安装包 apache-tomcat-7.0.67.zip jdk安装包 jdk-6u10-linux-x64.bin 下载地址:http://www.oracle.com/tec ...
- android getActivity.findViewById获取ListView 返回NULL
在控件ID正确的情况下,检查是否在实例化布局文件之后,获取LISTVIEW, 先inflate找layout下布局文件,并实例化后才能获得Listview的ID demo: public class ...
- 20个实用的webApp前端开发技巧
自Iphone和Android这两个牛逼的手机操作系统发布以来,在互联网界从此就多了一个新的名词-WebApp(意为基于WEB形式的应用程序,运行在高端的移动终端设备). 开发者们都知道在高端智能手机 ...
- cf1104d二分+数学
#include<bits/stdc++.h> using namespace std; bool ask(int x,int y){ printf("? %d %d\n&quo ...
- 性能测试十八:jmeter分布式
一台压力机产生得压力是有限的,尤其是jmeter,java本来性能就不是很好,并发特别多的时候,jmeter的性能会急剧下降,正常的接口,若单台压力机,超过1000并发以后,jmeter的性能就不怎么 ...
- python 全栈开发,Day33(tcp协议和udp协议,互联网协议与osi模型,socket概念,套接字(socket)初使用)
先来回顾一下昨天的内容 网络编程开发架构 B/S C/S架构网卡 mac地址网段 ip地址 : 表示了一台电脑在网络中的位置 子网掩码 : ip和子网掩码按位与得到网段 网关ip : 内置在路由器中的 ...
- For each loop in Native C++
今天发现 for each 语法居然可以直接编译通过,之前还以为只有开了/clr才可以支持.查了一下资料发现ms从vs2005就已经支持了.虽然不符合标准不过用着确实方便啊,必须记录一下. 具体看这里 ...
- django的FormView中,自定义初始化表单数据的曲折方法
这个技巧,主要是用于表单初始化及回显. 也就是说,如果用户的数据库里有数据,则要将相应的数据显示在表单里, 如果用户的数据库里没有数据,才会生成一个空白的表单给用户, 这样才显得专业塞! 而我面对的尴 ...
- Struts2(接受表单参数)请求数据自动封装和数据类型转换
Struts2请求数据自动封装: (1)实现原理:参数拦截器 (2)方式1:jsp表单数据填充到action中的属性: 普通的成员变量,必须给set,get可以不给的. 注意点,A ...