STL源码剖析 迭代器(iterator)概念与编程技法(三)

1 STL迭代器原理

1.1  迭代器(iterator)是一中检查容器内元素并遍历元素的数据类型,STL设计的精髓在于,把容器(Containers)和算法(Algorithms)分开,而迭代器(iterator)就是这个桥梁。

1.2  迭代器(iterator)类型

STL源码剖析 迭代器(iterator)概念与编程技法(三)

1.3 迭代器功能说明

迭代器类别          说明
输入 从容器中读取元素。输入迭代器只能一次读入一个元素向前移动,输入迭代器只支持一遍算法,同一  个输入迭代能两遍遍历一个序列
输出   向容器中写入元素。输出迭代器只能一次一个元素向前移动。输出迭代器只支持一遍算法,统一输出 迭代器不能两次遍历一 个序列
正向  组合输入迭代器和输出迭代器的功能,并保留在容器中的位置
双向   组合正向迭代器和逆向迭代器的功能,支持多遍算法
随机访问 组合双向迭代器的功能与直接访问容器中任何元素的功能,即可向前向后跳过任意个元素
   
   

1.4 参考图例和迭代器的操作:

每种迭代器均可进行包括表中前一种迭代器可进行的操作

迭代器操作

说明

所有迭代器

p++

后置自增迭代器

++p

前置自增迭代器

输入迭代器

*p

复引用迭代器,作为右值

p=p1

将一个迭代器赋给另一个迭代器

p==p1

比较迭代器的相等性

p!=p1

比较迭代器的不等性

输出迭代器

*p

复引用迭代器,作为左值

p=p1

将一个迭代器赋给另一个迭代器

正向迭代器

提供输入输出迭代器的所有功能

双向迭代器

--p

前置自减迭代器

p--

后置自减迭代器

随机迭代器

p+=i

将迭代器递增i位

p-=i

将迭代器递减i位

p+i

在p位加i位后的迭代器

p-i

在p位减i位后的迭代器

p[i]

返回p位元素偏离i位的元素引用

p<p1

如果迭代器p的位置在p1前,返回true,否则返回false

p<=p1

p的位置在p1的前面或同一位置时返回true,否则返回false

p>p1

如果迭代器p的位置在p1后,返回true,否则返回false

p>=p1

p的位置在p1的后面或同一位置时返回true,否则返回false

STL源码剖析 迭代器(iterator)概念与编程技法(三)

2 STL迭代器作用

迭代器的作用其实相当于一个智能指针,它指向容器内部的数据,可以通过operator *操作符来解指针获得数据的值,也可以通过operator ->操作符来获取数据的指针,还能够重载++,--等运算符来移动指针。

3 迭代器(iterator)延伸

网站:http://www.cplusplus.com/reference/iterator/

4 容器支持迭代器(iterator)如下

容器

支持的迭代器类别

说明

vector

随机访问

一种随机访问的数组类型,提供了对数组元素进行快速随机访问以及在序列尾部进行快速的插入和删除操作的功能。可以再需要的时候修改其自身的大小

deque

随机访问

一种随机访问的数组类型,提供了序列两端快速进行插入和删除操作的功能。可以再需要的时候修改其自身的大小

list

双向

一种不支持随机访问的数组类型,插入和删除所花费的时间是固定的,与位置无关。

set

双向

一种随机存取的容器,其关键字和数据元素是同一个值。所有元素都必须具有惟一值。

multiset

双向

一种随机存取的容器,其关键字和数据元素是同一个值。可以包含重复的元素。

map

双向

一种包含成对数值的容器,一个值是实际数据值,另一个是用来寻找数据的关键字。一个特定的关键字只能与一个元素关联。

multimap

双向

一种包含成对数值的容器,一个值是实际数据值,另一个是用来寻找数据的关键字。一个关键字可以与多个数据元素关联。

stack

不支持

适配器容器类型,用vector,deque或list对象创建了一个先进后出容器

queue

不支持

适配器容器类型,用deque或list对象创建了一个先进先出容器

priority_queue

不支持

适配器容器类型,用vector或deque对象创建了一个排序队列

ok上面基本包括了STl源码剖析(侯杰)第三章的基本知识点,deque、map、list、stack、vector是我下面重点学习的内容,其他的需要在提出吧!(当然上面所以知识点都可以在迭代器(iterator)延伸中查找!)

期待将持续更新,敬请关注! syw_selfimpr新浪微博地址: http://weibo.com/u/2945271402

注:以上由本人整理学习,为经本人同意请勿传播、copy,转载请说明出处,谢谢!

上一篇:AndroidManifest.xml的targetSdkVersion 与 project.properties中target


下一篇:linux下so动态库一些不为人知的秘密(转)