为什么使用迭代器访问vector比运算符[]访问要慢那么多?

JinCraft 2013-04-20 12:03:33
环境VS2010
debug版迭代器比[]慢几十倍,这是怎么回事啊?
是不是所有STL的实现都是这样?
...全文
249 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
ri_aje 2013-04-20
  • 打赏
  • 举报
回复
研究 debug 版的速度就没什么用,速度根本不是 debug build 的目标。
飞天御剑流 2013-04-20
  • 打赏
  • 举报
回复
要养成提问同时贴上代码的习惯。
赵4老师 2013-04-20
  • 打赏
  • 举报
回复
对学习编程者的忠告: 眼过千遍不如手过一遍! 书看千行不如手敲一行! 手敲千行不如单步一行! 单步源代码千行不如单步对应汇编一行! 单步类的实例“构造”或“复制”或“作为函数参数”或“作为函数返回值返回”或“参加各种运算”或“退出作用域”的语句对应的汇编代码几步后,就会来到该类的“构造函数”或“复制构造函数”或“运算符重载”或“析构函数”对应的C/C++源代码处。 VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。 对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
wuxupu 2013-04-20
  • 打赏
  • 举报
回复
vector的迭代器就是原生指针

template <class T, class Alloc = alloc>
class vector {
    typedef T              value_type;
    typedef value_type*    iterator;
    typedef value_type&    reference;
    ...
protected:
    iterator start;
    iterator finish;
    iterator end_of_storage;
    ...
public:
    ...
    iterator begin() {return start;}
    reference operator[](size_type n) {return *(begin() + n);}
    ...
};

64,685

社区成员

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

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