我目前正在编写一个需要尽可能好地执行的应用程序。我使用 VS2012 作为我的 IDE(和编译器)。
我注意到,当我对向量进行迭代时,与迭代器相比,指针解决方案在速度方面要快得多。这是为什么?我的意思是,迭代器基本上是一样的。至少应该是这样。
看看这个例子:
std::vector<int> v;
for (std::vector<int>::iterator it = v.begin(); it != v.end(); it++) {
// Do stuff with *it
}
for (int* i = &v[0], i <= &v[v.size()-1]; i++) {
// Do stuff with *i
}
编译器是否需要任何优化?我正在使用所有标准设置,所以 -O2 已经启用。提前致谢。
编辑: 我在 Release 中编译,并使用 Ctrl+F5 运行(即没有调试)。
EDIT2: 实际的源代码是快速排序的实现。这是完整源代码的链接,非常短,请查看。