STL学习记录(十):Iterator
来源:互联网 发布:彩虹秒赞源码破解 编辑:程序博客网 时间:2024/06/06 14:28
STL之迭代器
STL迭代器Iterator
迭代器简介
迭代器Iterator是每个容器都有的。它的作用有点类型指针,标识着容器里的每一个元素。迭代器也有类型区别,不同类型的迭代器功能不同。例如排序算法中就要求迭代器的类型必须是支持随机访问的迭代器(RandomAccess Iterator)。迭代器的类型主要分为:Output Iterator、Input iterator、Forward Iterator、Bidirectional Iterator、RandomAccess Iterator。这五类迭代器的关系与区别如图1。从图中可以发现随机访问迭代器支持的操作最多,其次是双向迭代器。
Output Iterator
输入迭代器只能进行向前的迭代操作而不能后退,这也就表明如果你想进行赋值操作的话也只能从前往后进行赋值,并且不能通过输出迭代器迭代访问某个相同的范围两次。输出迭代器没有比较操作,你无法得知某个输出迭代器是否有效或者迭代器的写操作是否成功完成。这里需要注意的是所有const类型的迭代器都不是输出迭代器,因为const类型的迭代器不支持赋值操作。输出型迭代器操作如下:
Input Iterator
输入迭代器只能依次序向前迭代并且只能进行读操作,这说明输入迭代器对每一个元素只能进行一次访问。因此如果对某个输入迭代器进行拷贝操作,拷贝后的迭代器与原迭代器同时迭代操作的时候可能访问的不是同一个值。
Forward Iterator
与输入迭代器不同,单向迭代器保证如果两个迭代器指向同一位置==操作会返回true,拷贝后的迭代器与原迭代器同时迭代操作的时候可能访问的是同一个值。
Bidirectional Iterators
双向迭代器与单向迭代器提供相同操作,除此之外还提供额外的操作
RandomAccess Iterator
随机访问迭代器则是在双向迭代器的基础上在添加了随机访问操作。
一些辅助性迭代器函数
advance( )
该函数对某个迭代器进行迭代操作,向前或者向后(如果支持的话)迭代多个单位。需要注意的是因为迭代器不知道它所迭代的容器,该函数不保证迭代过程中迭代器位于合法位置,所以可能导致未定义行为,当迭代到容器末尾。实例代码:
#include <iterator>#include <iostream>#include <list>#include <algorithm>using namespace std;int main() { list<int> coll; for(int i=1;i<9;++i) { coll.push_back(i); } list<int>::iterator pos = coll.begin(); cout<<*pos<<endl; advance(pos,3); cout<<*pos<<endl; advance(pos,-1); cout<<*pos<<endl;}
输出为:
1
4
3
next( ) and prev( )
这两个函数是c++11中支持的,主要是让迭代器移动到前一个或者后一个上面。需要注意的是操作与迭代器类型有关Forward iterator就不支持prev( )操作,另外这两个操作不会进行范围检查需要用户自己保证范围合法。
distance( )
该操作主要是返回两个迭代器之间的距离。
iter_swap( )
该操作是交换两个迭代器所指元素的值。
实例代码:
#include <iostream>#include <list>#include <iterator>using namespace std;int main(){ list<int> coll; for(int i=0;i<9;i++) coll.push_back(i); for(const auto &item:coll) cout<<" "<<item; cout<<endl; iter_swap(coll.begin(),next(coll.begin())); for(const auto &item:coll) cout<<" "<<item; cout<<endl; iter_swap(coll.begin(),prev(coll.end())); for(const auto &item:coll) cout<<" "<<item; cout<<endl; return 0;}
输出为:
0 1 2 3 4 5 6 7 8
1 0 2 3 4 5 6 7 8
8 0 2 3 4 5 6 7 1
- STL学习记录(十):Iterator
- STL学习----入门(1)[iterator]
- STL学习记录(一):STL简介
- STL迭代器(iterator)
- C++ STL学习 List iterator
- STL学习笔记之迭代器--iterator(源码剖析)
- [原创]STL Iterator,traits学习笔记
- stl 学习笔记14 Reverse Iterator
- STL学习笔记之迭代器--iterator
- STL学习记录(二):迭代器简要
- STL学习记录(四):Vector
- STL学习记录(五):Deque
- STL学习记录(六):List
- STL学习记录(七):Forward List
- STL学习记录(八)Sets、Multisets
- STL学习记录(九)Maps、Multimaps
- STL学习记录(十五):Stack
- Effective STL学习记录
- 关于fopen的模式问题
- Matlab图像处理系列1———线性变换和直方图均衡
- 【Caffe代码解析】Blob
- 文件操作之fread函数和fwrite函数
- 硬牌九控牌绝技◥〓【在线演示QQ:194714506】
- STL学习记录(十):Iterator
- ExoPlayer类说明
- android ViewPager使用
- CCNA学习指南 以大网和数据封装
- 小9扑克控牌技巧卐╭【在线演示QQ:194714506】
- java将XML文档转换成json格式数据
- 浅析malloc的几种实现方式
- 小9扑克控牌教学▅∑【在线演示QQ:194714506】
- xshell ssh 登陆虚拟机,ssh 服务器拒绝