C++ stl vector不同遍历方式性能比较
2016-01-10 14:18
573 查看
系统:win7
ide:vs2012
今天闲来无事,想测试一下vector不同遍历方式性能有多少差别,先上代码
debug模式下运行三次,结果如下:
可以看到方式三的性能远胜于前两种,三和一差了十几倍,这个差别有点大了,不过别急我们再看看release模式下运行状况,如图:
刚开始看到这结果时我是这样的
。怎么会是0,怎么可以是0,难道我的代码有bug!
然后我想这应该是被编译器优化了,那三段代码根本没执行,于是我在后面加了一句cout << tempNum << endl;
再试一试,看图:
哦耶,有结果了,可以看到三种方式差别很小,写代码时可以不用纠结用什么比较高效。
ide:vs2012
今天闲来无事,想测试一下vector不同遍历方式性能有多少差别,先上代码
#include <iostream> #include <vector> #include <windows.h> using namespace std; int main() { // 创建vector,插入一百万条数据 std::vector<int> vecTest; const int VEC_SIZE = 1000000; vecTest.reserve(VEC_SIZE); for (int i = 0; i < VEC_SIZE; i++) { vecTest.push_back(i); } int tempNum = 0; const int TEST_TIMES = 100; LARGE_INTEGER freq; QueryPerformanceFrequency(&freq); LARGE_INTEGER time0, time1, time2, time3; QueryPerformanceCounter(&time0); // 遍历方式一 for (std::vector<int>::iterator it = vecTest.begin(); it != vecTest.end(); ++it) { tempNum = *it; } QueryPerformanceCounter(&time1); // 遍历方式二 for (auto it : vecTest) { tempNum = it; } QueryPerformanceCounter(&time2); // 遍历方式三 size_t maxCount = vecTest.size(); for (size_t i = 0; i < maxCount; i++) { tempNum = vecTest[i]; } QueryPerformanceCounter(&time3); double sec0 = (double)time0.QuadPart / freq.QuadPart; double sec1 = (double)time1.QuadPart / freq.QuadPart; double sec2 = (double)time2.QuadPart / freq.QuadPart; double sec3 = (double)time3.QuadPart / freq.QuadPart; cout << "方式一 : " << sec1 - sec0 << endl; cout << "方式二 : " << sec2 - sec1 << endl; cout << "方式三 : " << sec3 - sec2 << endl; system("pause"); return 0; }
debug模式下运行三次,结果如下:
可以看到方式三的性能远胜于前两种,三和一差了十几倍,这个差别有点大了,不过别急我们再看看release模式下运行状况,如图:
刚开始看到这结果时我是这样的
。怎么会是0,怎么可以是0,难道我的代码有bug!
然后我想这应该是被编译器优化了,那三段代码根本没执行,于是我在后面加了一句cout << tempNum << endl;
再试一试,看图:
哦耶,有结果了,可以看到三种方式差别很小,写代码时可以不用纠结用什么比较高效。
相关文章推荐
- 使用C++实现JNI接口需要注意的事项
- 关于指针的一些事情
- c++ primer 第五版 笔记前言
- share_ptr的几个注意点
- 选定虚拟主机 性能凸显优势
- 文件遍历排序函数
- 修改一行代码提升 Postgres 性能 100 倍
- 推荐Sql server一些常见性能问题的解决方法
- Lua 学习笔记之C API 遍历 Table实现代码
- Lua中调用C++函数示例
- Lua教程(一):在C++中嵌入Lua脚本
- Lua教程(二):C++和Lua相互传递数据示例
- SQL Server误区30日谈 第9天 数据库文件收缩不会影响性能
- 和表值函数连接引发的性能问题分析
- SQLServer 2000 升级到 SQLServer 2008 性能之需要注意的地方之一
- 数据库性能优化三:程序操作优化提升性能
- C#遍历文件夹后上传文件夹中所有文件错误案例分析
- C#中遍历Hashtable的4种方法
- VBS中的字符串连接的性能问题
- C++联合体转换成C#结构的实现方法