关于迭代器访问

liushui9 2012-06-23 11:35:08
如果定义list<int>::iterator it,若需按偶数进行跳跃式访问,可采用迭代器操作it+=2。这句话对吗?
...全文
114 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq120848369 2012-06-23
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 的回复:]

有个函数叫做:advance,你可以用一下,其实就是一个模板函数去调用不同类型迭代器为形参重载函数。
[/Quote]

会用的advance从实现角度讲会用到:iterator_traits, 以及重载函数的使用。

希望在C++语言方面深入一点,这些相关知识都可以在《STL源码剖析》里学习全面。
qq120848369 2012-06-23
  • 打赏
  • 举报
回复
有个函数叫做:advance,你可以用一下,其实就是一个模板函数去调用不同类型迭代器为形参重载函数。
liushui9 2012-06-23
  • 打赏
  • 举报
回复
可以再问一下,如果想要偶数进行跳跃式访问,应该怎么操作吗?
qq120848369 2012-06-23
  • 打赏
  • 举报
回复
不对, 虽然原理上可以, 可惜实现上禁止了.
  • 打赏
  • 举报
回复
可以自增两次。
iamnobody 2012-06-23
  • 打赏
  • 举报
回复
list 的迭代器类型是 forward iterator 不支持 += 操作.所以不行.

64,282

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧