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的更多相关文章

  1. Java List中迭代器遍历

    在java中,List接口从Collection接口中继承了 iterator()函数,返回值是一个T类型的迭代器(泛型),T是List中元素的类型 public class TestListAndI ...

  2. java 迭代器遍历List Set Map

    Iterator接口: 所有实现了Collection接口的容器类都有一个iterator方法用以返回一个实现Iterator接口的对象 Iterator对象称作为迭代器,用以方便的对容器内元素的遍历 ...

  3. Iterator、for..of,for...in和自定义遍历器**

    Iterator.for..of,for...in和自定义遍历器 Iterator: var arr = [1,2,3,4,5]; var ite = arr[Symbol.iterator](); ...

  4. ES6的 Iterator 遍历器到底是什么?

    这节课要讲的是ES6中的Iterator. for...of为啥不遍历Object对象 第十三节我们讲了简单又实用的for...of,我们可以使用它来遍历数组,字符串,Set和Map结构,但是有没有发 ...

  5. Java基础知识强化之集合框架笔记07:Collection集合的遍历之迭代器遍历

    1. Collection的迭代器: Iterator iterator():迭代器,集合的专用遍历方式 2. 代码示例: package cn.itcast_03; import java.util ...

  6. Redis Scan迭代器遍历操作原理(一)

    Redis在2.8.0版本新增了众望所归的scan操作,从此再也不用担心敲入了keys*, 然后举起双手看着键盘等待漫长的系统卡死了··· 命令的官方介绍在这里, 中文版由huangz同学细心翻译了, ...

  7. Redis Scan迭代器遍历操作原理(二)

    续上一篇文章 Redis Scan迭代器遍历操作原理(一)–基础 ,这里着重讲一下dictScan函数的原理,其实也就是redis SCAN操作最有价值(也是最难懂的部分). 关于这个算法的源头,来自 ...

  8. Java 中List 集合索引遍历与迭代器遍历

    package yzhou.iterator; import java.util.ArrayList; import java.util.HashSet; import java.util.Itera ...

  9. 有关map中使用iterate迭代器遍历的不保序问题和list remove(object)的细节问题

    今天在做项目的过程中发现了如下两个问题: 一 使用map的iterator迭代器对map进行遍历得到的结果是不保序的,也就是每次输出结果都是不一样的.针对这个问题,看以下iterator迭代器的源码. ...

随机推荐

  1. pom.xml的第一行报错

    第一行:<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.or ...

  2. javascript 类型比较方法

    不要使用new Number().new Boolean().new String()创建包装对象: 用parseInt()或parseFloat()来转换任意类型到number: 用String() ...

  3. 2018-2019-2-20175225 实验二《Java开发环境的熟悉》实验报告

    姓名:张元瑞 学号:20175225 班级:1752 实验课程:JAVA程序设计 实验名称:Java面向对象程序设计 实验时间:2019.4.16 指导老师:娄嘉鹏 实验内容 测试点一 - " ...

  4. Math对象应用详解

    JavaScript中的Math对象提供了大量的算术运算功能和数值操作方法. JavaScript中的Math对象的与众不同之处在于,它是一个全局对象.在使用Math对象之前,既不需要将一个变量声明为 ...

  5. ie6 表格td中无内容时不显示边框的解决办法

    1.在单元格中加入一个空格.这样: <td> </td> 2.直接在table里这样写:<table border="0" cellspacing=& ...

  6. Neural style transfer

    网络风格迁移 作者:无用 本文通过学习吴恩达视频所做笔记 目录 简介 可视化卷积层 构建风格迁移网络 一.网络风格迁移简介 二.可视化卷积层 可视化深层卷积网络???这个问题我看过一篇文章,我会在后补 ...

  7. laravel使用when搜索遇到状态参数(有0的状态)的坑

    今天,使用when()方法写活动列表的接口,有两个状态搜索,都有0这个状态,当传参为0时when()就失效了... 反反复复的验证参数,传参确实是0和1啊...百思不得其解~~~后面仔细想想when( ...

  8. 用PNChart绘制饼状图简介

    写在前面 最近做的小Demo中有一个绘制饼状图的需求.在开始实现之前上网了解了一下现有的一些绘制图形的第三方库,相应的库还是有挺多的,PNChart便是其中一个.PNChart是一个90后的中国boy ...

  9. DDD领域模型数据访问权限之权限(十二)

    实现权限的领域对象:BAS_Permission public partial class BAS_Permission:AggreateRoot { private IRepository<B ...

  10. (canvas)两小球碰撞后的速度问题研究

    这两天在研究canvas碰撞 先把小球开始运动的图拿出来 参考了一下别的的代码,在两个小球碰撞处理上,我觉得不完善 怎么样处理才算完善呢,当然是要用高中物理学的动量守恒了和机械能守恒了 机械能守恒我其 ...