扩充STL-编写自己的迭代器
这里的迭代器能够与STL组件共同工作,是对STL的一种扩充。
自定义迭代器必须提供iterator_traits的五种特性,分别是迭代器类型、元素类型、距离类型、指针类型与reference类型。
这里我们继承标准库提供的iterator<>即可。
代码如下: MyIterator.hpp 该迭代器针对于关联容器
#ifndef MYITERATOR_H_
#define MYITERATOR_H_ #include <iterator> //必须提供五种类型,作为迭代器traits
template <typename Container>
class MyInsertIterator : public std::iterator<std::output_iterator_tag,
void, void, void, void>
{
public:
explicit MyInsertIterator(Container &c)
:container_(c)
{ } //将赋值转化为insert操作
MyInsertIterator<Container> &operator=(const typename Container::value_type &value)
{
container_.insert(value); //针对的是关联容器
return *this;
} //没有实际动作,起到掩饰的作用
MyInsertIterator<Container> operator*()
{
return *this;
} MyInsertIterator &operator++()
{
return *this;
} MyInsertIterator &operator++(int)
{
return *this;
} protected:
Container &container_;
}; template <typename Container>
MyInsertIterator<Container> MyInsert(Container &c)
{
return MyInsertIterator<Container>(c);
} #endif /* MYITERATOR_H_ */
这里面重载的*和++没有实际操作,为的是起到掩饰的作用,从而仅仅返回自身引用。
注意=操作符执行了insert操作,所以当我们写下:
*iter = 3;
时,自动将3插入至容器中。
我们还提供了一个MyInsert函数,用于快速生成迭代器对象,于是我们可以这样使用:
MyInsert(coll) = 55;
我们只需改动代码中的
container_.insert(value); //针对的是关联容器
如果改为push_back就变成了back_inserter,如果调用push_front则成为front_inserter
测试代码如下:
#include "MyIterator.hpp"
#include <set>
#include <string>
#include <iostream>
using namespace std; template <typename CONT>
void print(const CONT &s)
{
for(typename CONT::const_iterator it = s.begin();
it != s.end();
++it)
{
cout << *it << " ";
}
cout << endl;
} int main(int argc, char const *argv[])
{
set<int> coll; MyInsertIterator<set<int> > iter(coll); *iter = 1;
iter++;
*iter = 2;
iter++;
*iter = 3; print(coll); MyInsert(coll) = 44;
MyInsert(coll) = 55; print(coll); int vals[] = {33, 67, -4, 13, 5, 2};
int size = sizeof(vals) / sizeof(vals[0]);
copy(vals, vals + size, MyInsert(coll)); print(coll); return 0;
}
结果为:
1 2 3
1 2 3 44 55
-4 1 2 3 5 13 33 44 55 67
扩充STL-编写自己的迭代器的更多相关文章
- stl之容器、迭代器、算法几者之间的关系
转自:https://blog.csdn.net/bobodem/article/details/49386131 stl包括容器.迭代器和算法: 容器 用于管理一些相关的数据类型.每种容器都有它的优 ...
- SGI STL红黑树中迭代器的边界值分析
前言 一段程序最容易出错的就是在判断或者是情况分类的边界地方,所以,应该对于许多判断或者是情况分类的边界要格外的注意.下面,就分析下STL中红黑树的迭代器的各种边界情况.(注意:分析中STL使用的版本 ...
- STL的erase()陷阱-迭代器失效总结
下面材料整理自Internet&著作. STL中的容器按存储方式分为两类,一类是按以数组形式存储的容器(如:vector .deque):另一类是以不连续的节点形式存储的容器(如:list.s ...
- STL六大组件之——迭代器这个东西
迭代器:除了在其它语言中司空见惯的下标法访问容器元素之外,C++语言提供了一种全新的方法——迭代器(iterator)来访问容器的元素.迭代器其实类似于引用,指向容器中某一元素.换个方式来说,容器就是 ...
- STL源码剖析 迭代器(iterator)概念与编程技法(三)
1 STL迭代器原理 1.1 迭代器(iterator)是一中检查容器内元素并遍历元素的数据类型,STL设计的精髓在于,把容器(Containers)和算法(Algorithms)分开,而迭代器(i ...
- STL的容器算法迭代器的设计理念
1) STL的容器通过类模板技术,实现数据类型和容器模型的分离. 2) STL的迭代器技术实现了遍历容器的统一方法:也为STL的算法提供了统一性. 3) STL的函数对象实现了自定义数据类型的算法运算 ...
- STL源码剖析(迭代器)
在STL中,容器跟算法是分开设计的,算法是通过迭代器来对容器进行操作的. 在算法运用迭代器的时候,可能会用到其相应的型别,例如返回值为容器中元素的型别,又或者说根据迭代器的类型来选择更好的算法等等. ...
- STL源码剖析--迭代器(转)
一.为什么需要traits编程技术 前面说了很多关于traits的光荣事迹,但是却一直没有介绍traits究竟是个什么东西,究竟是用来干什么的?traits在英文解释中就是特性,下面将会引入trait ...
- 实战c++中的vector系列--vector的遍历(stl算法、vector迭代器(不要在循环中推断不等于end())、operator[])
遍历一个vector容器有非常多种方法.使用起来也是仁者见仁. 通过索引遍历: for (i = 0; i<v.size(); i++) { cout << v[i] << ...
随机推荐
- Linux下Nginx使用
1. 安装 CentOS 7上Nginx的安装和启动方法如下 # yum install nginx # firewall-cmd --permanent --zone=public --add-se ...
- off charging mode flow
/system/core/init/init.cpp ..... ..... ..... int main(int argc, char** argv) { ..... ..... ..... // ...
- Linux学习总结—缺页中断和交换技术【转】
三.Linux缺页中断处理 转自:http://blog.csdn.net/cxylaf/article/details/1626534 1.请求调页中断: 进程线性地址空间里的页面不必常驻内存,例如 ...
- 如何让natTable表格支持自定义多个右键菜单
在nebula中,官方默认提供了一个构造natTable的builder类,并且提供了一个debugInfo的默认右键菜单,但是当我们通过官方提供的builder去创建natTable,并且要添加多个 ...
- Python的并发并行[4] -> 并发[1] -> concurrent.future 模块
concurrent.future 模块 1 thread模块 / thread Module 1.1 常量 / Constants Pass 1.2 函数 / Function Pass 1.3 类 ...
- MySQL-python install
Redhat 7.6 yum install python-devel mysql-devel gcc -y pip install MySQL-python==1.2.5
- Xcode_9_beta.xip 更新下载
Xcode_9_beta.xip 更新下载 Xcode_9_beta.xip 链接: pan.baidu.com/s/1dFJ33tJ 密码: 89mv
- 面向对象-QuickHit项目
package com.ketang.game; /** * 游戏级别类 * @author * */ public class Level { private int levelNo; //各级别编 ...
- jsp homework(*)
3.编写一个JSP程序实现手表的功能,显示当前时间(时:分:秒),并不停地自动刷新时间. 方法一[scriptlet] <%@ page language="java" im ...
- QQ协议
http://www.cnblogs.com/sufei/archive/2012/12/13/2816737.html http://www.360doc.com/content/12/0822/1 ...