STL迭代器简介

 

标准模板库(The Standard Template Library, STL)定义了五种迭代器。下面的图表画出了这几种:

            input         output
              \            /
                 forward
                     |
                bidirectional
                     |
               random access

 
 

要注意,上面这图表并不是表明它们之间的继承关系:而只是描述了迭代器的种类和接口。处于图表下层的迭代器都是相对于处于图表上层迭代器的扩张集。例如:forward迭代器不但拥有input和output迭代器的所有功能,还拥有更多的功能。

各个迭代器的功能如下:

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

迭代器的操作:

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

迭代器操作说明
所有迭代器
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<=p1p的位置在p1的前面或同一位置时返回true,否则返回false
p>p1如果迭代器p的位置在p1后,返回true,否则返回false
p>=p1p的位置在p1的后面或同一位置时返回true,否则返回false

只有顺序容器和关联容器支持迭代器遍历,各容器支持的迭代器的类别如下:

容器支持的迭代器类别
vector随机访问
deque随机访问
list双向
set双向
multiset双向
map双向
multimap双向
stack不支持
queue不支持
priority_queue不支持
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值