当前位置:首页 > 科技  > 软件

C++循环优化:提升性能的关键技巧

来源: 责编: 时间:2023-09-28 10:08:51 404观看
导读在C++编程中,循环是一种常见的结构,然而,通常情况下,我们可能会忽视循环中的一些细微的效率问题,这些问题可能会导致大量的时间浪费。本文将介绍一些优化C++循环的技巧,帮助您提升程序的性能。典型的“未优化”C++循环我们

在C++编程中,循环是一种常见的结构,然而,通常情况下,我们可能会忽视循环中的一些细微的效率问题,这些问题可能会导致大量的时间浪费。本文将介绍一些优化C++循环的技巧,帮助您提升程序的性能。7Us28资讯网——每日最新资讯28at.com

7Us28资讯网——每日最新资讯28at.com

典型的“未优化”C++循环

我们首先来看一个典型的“未优化”C++循环示例:7Us28资讯网——每日最新资讯28at.com

int main(){  std::vector<uint32_t> vec;  // 填充向量  for(int i=0; i<10000000; i++)  {    vec.push_back(i);  }  // 对向量的值进行1000次求和  for (int i = 0; i < 1000; i++)  {    uint64_t sum = 0;    for (std::vector<uint32_t>::const_iterator itr = vec.begin();        itr != vec.end();        itr++)    {      sum += *itr;    }    std::cout << sum << std::endl;  }}

7Us28资讯网——每日最新资讯28at.com

在没有进行任何优化的情况下,该代码的执行时间为551.97秒。7Us28资讯网——每日最新资讯28at.com

使用缓存的“end()”迭代器

该优化技巧主要是避免在每次循环迭代时对vec.end()进行查找,而是将其缓存起来,以避免重复查找的开销。代码示例如下:7Us28资讯网——每日最新资讯28at.com

int main(){  std::vector<uint32_t> vec;  for(int i=0; i<10000000; i++)  {    vec.push_back(i);  }  for (int i=0; i<1000; i++)  {    uint64_t sum = 0;    // 缓存vec.end()以避免重复查找    std::vector<uint32_t>::const_iterator itr, end(vec.end());     for (itr = vec.begin();        itr != end;        itr++)    {      sum += *itr;    }    std::cout << sum << std::endl;  }}

7Us28资讯网——每日最新资讯28at.com

经过该优化后,代码的执行时间减少至524.81秒,相比未优化版本有了5%的改进。7Us28资讯网——每日最新资讯28at.com

使用前置递增代替后置递增迭代器

将后置递增(itr++)改为前置递增(++itr)是一种简单的优化方法,它可以显著提高循环的执行效率。代码示例如下:7Us28资讯网——每日最新资讯28at.com

int main(){  std::vector<uint32_t> vec;  // 使用前置递增代替后置递增  for(int i=0; i<10000000; ++i)  {    vec.push_back(i);  }  for (int i=0; i<1000; ++i)  {    uint64_t sum = 0;    std::vector<uint32_t>::const_iterator itr, end(vec.end());    // 使用前置递增代替后置递增    for (itr = vec.begin();        itr != end;        ++itr)    {      sum += *itr;    }    std::cout << sum << std::endl;  }}

7Us28资讯网——每日最新资讯28at.com

经过这一简单的改变,代码的执行时间减少至323.58秒,相比未优化版本有了38%的改进。7Us28资讯网——每日最新资讯28at.com

使用std::for_each算法

我们可以使用std::for_each算法来进一步优化循环。std::for_each算法会自动缓存.end()并使用前置递增代替后置递增操作。但需要注意的是,在关闭优化的情况下,编译器无法内联调用Sum和Increment函数,这可能会导致性能下降。代码示例如下:7Us28资讯网——每日最新资讯28at.com

struct Sum{  uint64_t m_sum;  Sum()    : m_sum(0)  {  }  void operator()(uint32_t i)  {    m_sum += i;  }};struct Increment{  int m_value;  Increment(int i)    : m_value(i)  {  }  int operator()()  {    return m_value++;  }};int main(){  std::vector<uint32_t> vec;  // 使用Increment生成器生成10000000个值  std::generate_n(back_inserter(vec), 10000000, Increment(0));  for (int i = 0; i < 1000; ++i)  {    uint64_t sum = 0;    // 使用std::for_each进行循环求和    std::for_each(vec.begin(), vec.end(), Sum(sum));    std::cout << sum << std::endl;  }}

7Us28资讯网——每日最新资讯28at.com

需要注意的是,这种优化方法在关闭优化的情况下可能会导致效率下降。7Us28资讯网——每日最新资讯28at.com

结论:

通过对循环进行优化,我们可以显著提升C++程序的性能。关键的优化技巧包括缓存迭代器、使用前置递增代替后置递增以及使用适当的算法(如std::for_each)。然而,在进行优化时,我们需要注意优化对于特定编译器和环境的适用性,以及可能引入的副作用。7Us28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-11876-0.htmlC++循环优化:提升性能的关键技巧

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 八个重构技巧使得Python代码更Pythonic

下一篇: 高效定时任务处理:深入学习Python中APScheduler库的奥秘

标签:
  • 热门焦点
  • 7月安卓手机好评榜:三星S23Ultra好评率第一

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年7月1日至7月31日,仅限国内市场。第一名:三星Galaxy S23 Ultra好评率:95.71%在即将迎来新
  • 5月iOS设备性能榜:M1 M2依旧是榜单前五

    和上个月一样,没有新品发布的iOS设备性能榜的上榜设备并没有什么更替,仅仅只有跑分变化而产生的排名变动,刚刚开始的苹果WWDC2023,推出的产品也依旧是新款Mac Pro、新款Mac Stu
  • 轿车从天而降电动车主被撞身亡 超速抢道所致:现场视频让网友吵翻

    近日,上海青浦区法院判决轿车从天而降电动车主被撞身亡案,轿车车主被判有期徒刑一年。案件显示当时男子驾驶轿车在上海某路段行驶,前车忽然转弯提速超车,
  • 掘力计划第 20 期:Flutter 混合开发的混乱之治

    在掘力计划系列活动第20场,《Flutter 开发实战详解》作者,掘金优秀作者,Github GSY 系列目负责人恋猫的小郭分享了Flutter 混合开发的混乱之治。Flutter 基于自研的 Skia 引擎
  • 每天一道面试题-CPU伪共享

    前言:了不起:又到了每天一到面试题的时候了!学弟,最近学习的怎么样啊 了不起学弟:最近学习的还不错,每天都在学习,每天都在进步! 了不起:那你最近学习的什么呢? 了不起学弟:最近在学习C
  • 小红书1周涨粉49W+,我总结了小白可以用的N条涨粉笔记

    作者:黄河懂运营一条性教育视频,被54万人&ldquo;珍藏&rdquo;是什么体验?最近,情感博主@公主是用鲜花做的,火了!仅仅凭借一条视频,光小红书就有超过128万人,为她疯狂点赞!更疯狂的是,这
  • “又被陈思诚骗了”

    作者|张思齐 出品|众面(ID:ZhongMian_ZM)如今的国产悬疑电影,成了陈思诚的天下。最近大爆电影《消失的她》票房突破30亿断层夺魁暑期档,陈思诚再度风头无两。你可以说陈思诚的
  • 华为HarmonyOS 4升级计划公布:首批34款机型今日开启公测

    8月4日消息,今天下午华为正式发布了HarmonyOS 4系统,在更流畅的前提下,还带来了不少新功能,UI设计也有变化,会让手机焕然一新。华为宣布,首批机型将会在
  • 中关村论坛11月25日开幕,15位诺奖级大咖将发表演讲

    11月18日,记者从2022中关村论坛新闻发布会上获悉,中关村论坛将于11月25至30日在京举行。本届中关村论坛由科学技术部、国家发展改革委、工业和信息化部、国务
Top