小标
2018-12-26
来源 :
阅读 2599
评论 0
摘要:本文主要向大家介绍了 C/C++知识点之C++ std::vector 三种遍历方式的效率比较,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。
本文主要向大家介绍了 C/C++知识点之C++ std::vector 三种遍历方式的效率比较,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。
#include
#include
#include
#include
int main()
{
const uint32_t loop = 1000000;
std::vector
clock_t timeStart = 0;
for (uint32_t i = 0; i < loop; ++i)
{
vec.push_back(i);
}
// test time use
// 1.by index
timeStart = clock();
for (uint32_t i = 0; i < vec.size(); ++i)
{
vec[i];
}
std::cout << clock() - timeStart << "ms" << std::endl;
// 2.by iterator
timeStart = clock();
for (std::vector
{
*it;
}
std::cout << clock() - timeStart << "ms" << std::endl;
// 3.by auto iterator
timeStart = clock();
for (auto it = vec.begin(); it != vec.end(); ++it)
{
*it;
}
std::cout << clock() - timeStart << "ms" << std::endl;
getchar();
return 0;
}
代码很简单,构建一个包含若干个整数的vector,分别按照三种方式遍历,统计消耗时间,结果如下:
可以发现,按照传统下标方式遍历的效率快的不是一星半点,虽然这种方式容易发成写错下标而造成越界的情况,但是在代码提效的时候,是一个不可忽视的点。
本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标编程语言C/C+频道!
喜欢 | 0
不喜欢 | 0
您输入的评论内容中包含违禁敏感词
我知道了

请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号