给出c&c++程序优化的几个建议,希望对你有帮助
2013-07-03 10:16
225 查看
给出程序优化的几个建议,希望对你有帮助
如何写出高性能的C/C++代码一直是hack追求的境界,这里总结了一些常用的,希望对大家有用,欢迎拍砖,给出建议。
第一:记住,代码写完后一定要做一下系统优化,无论上面是否这样要求,但是这点很重要,是一种态度,当然优化可以借助各种工具如IBM和INTEL系列的优化工具,一般80%的时间被20%的代码所占用。
第二:如果你所在公司,对程序性能优化不重视,那么就请跳槽吧。
第三:要知道你所用编译器是怎么去优化多维数组访问的,如A[i][j]->A[i][j+1] 和A[i][j]->A[i+1][j]的访问速度对不同的编译器会有明显的速度差异,在里面涉及到cache block击中问题。
第四:关注多核处理器对浮点运算的处理方式。
第五:减少局部栈变量。我们知道任何系统给的栈空间的大小极为吝啬的,一般是1-4MB左右。如果栈变量过多,那么会导致一部分栈变量存在register里面,这会影响函数调用速度。
第六:尽量减少函数参数个数,如果不需要返回,就不要返回,减少栈深度。
第七:尽量用pass-by-reference 和指针传递参数,避免不必要的复制。
第八:尽量避免使用cast操作,这会产生一个temp变量,挤占register的空间,影响I./O效率。
第九:声明C++类的时候避免使用赋值构造
第十:正确写出轻量级的构造函数,如用A():a(0){}代替A(){a=0;}
第十一:尽量用位运算代替四则运算
第十二:谨慎使用函数跳转表
第十三:对自己定义的类,尽量用+= -= \= *= 代替+- * /
第十四:尽量延迟局部变量的声明和初始化
第十五:如果不影响计算的话,用prefix ++代替postfix++,对于用户自己定义的类,这两个操作符都要定义,防止客户误用
第十六:使用泛型编程看起来很酷,但是主流编译器对他的优化是有限的,尽量避免使用。
第十七:在计算过程过程中,避免动态内存操作。
第十八:搞清楚你硬件cache大小
第十九:避免不必要的初始化
第二十:尽量提前结束loop
第二十一:用数学公式去简化你的计算,如不要SB到用循环或者递归去计算等差数列的前N项和
第二十二:递归尽量少用,虽然很美,但是这回消耗本来就不富裕的栈空间
第二十三:尽量不要用虚函数。这会增加类的大小
第二十四:浮点计算和整形计算的速度没有你想的差距那么大,现在CPU都支持浮点运算,准备使用定点化计算的时候最好ray trace一下。综合考虑空间和时间上的效率
如何写出高性能的C/C++代码一直是hack追求的境界,这里总结了一些常用的,希望对大家有用,欢迎拍砖,给出建议。
第一:记住,代码写完后一定要做一下系统优化,无论上面是否这样要求,但是这点很重要,是一种态度,当然优化可以借助各种工具如IBM和INTEL系列的优化工具,一般80%的时间被20%的代码所占用。
第二:如果你所在公司,对程序性能优化不重视,那么就请跳槽吧。
第三:要知道你所用编译器是怎么去优化多维数组访问的,如A[i][j]->A[i][j+1] 和A[i][j]->A[i+1][j]的访问速度对不同的编译器会有明显的速度差异,在里面涉及到cache block击中问题。
第四:关注多核处理器对浮点运算的处理方式。
第五:减少局部栈变量。我们知道任何系统给的栈空间的大小极为吝啬的,一般是1-4MB左右。如果栈变量过多,那么会导致一部分栈变量存在register里面,这会影响函数调用速度。
第六:尽量减少函数参数个数,如果不需要返回,就不要返回,减少栈深度。
第七:尽量用pass-by-reference 和指针传递参数,避免不必要的复制。
第八:尽量避免使用cast操作,这会产生一个temp变量,挤占register的空间,影响I./O效率。
第九:声明C++类的时候避免使用赋值构造
第十:正确写出轻量级的构造函数,如用A():a(0){}代替A(){a=0;}
第十一:尽量用位运算代替四则运算
第十二:谨慎使用函数跳转表
第十三:对自己定义的类,尽量用+= -= \= *= 代替+- * /
第十四:尽量延迟局部变量的声明和初始化
第十五:如果不影响计算的话,用prefix ++代替postfix++,对于用户自己定义的类,这两个操作符都要定义,防止客户误用
第十六:使用泛型编程看起来很酷,但是主流编译器对他的优化是有限的,尽量避免使用。
第十七:在计算过程过程中,避免动态内存操作。
第十八:搞清楚你硬件cache大小
第十九:避免不必要的初始化
第二十:尽量提前结束loop
第二十一:用数学公式去简化你的计算,如不要SB到用循环或者递归去计算等差数列的前N项和
第二十二:递归尽量少用,虽然很美,但是这回消耗本来就不富裕的栈空间
第二十三:尽量不要用虚函数。这会增加类的大小
第二十四:浮点计算和整形计算的速度没有你想的差距那么大,现在CPU都支持浮点运算,准备使用定点化计算的时候最好ray trace一下。综合考虑空间和时间上的效率
相关文章推荐
- c&c++程序优化几个建议
- 系统获取数据性能优化方案,希望朋友们能够给出一些建议
- 微软MSDN给出的使用.Net开发Windows Form网络应用相关程序的优化建议
- 请大家看看这个随机发牌的小程序,希望给出点建议或者挑出点瑕疵
- 改善C++ 程序的150个建议学习之建议10:优化结构体中元素的布局
- 学习c++要了解的cin的几个输入函数为了让自己记住,也希望对大家有帮助,出错的话还希望多指教
- 改善C++程序的建议:语法篇1<从C继承而来的特性>
- UNIX下gprof来优化C/C++程序
- 编写高质量代码:改善C++程序的150个建议(八)
- 编写高质量代码:改善C++程序的150个建议(十二)
- 编写Spark程序的几个优化点
- Qt&nbsp;creator&nbsp;添加C++源码程序报错
- 通过引用优化c++程序,提高程序效率
- Linux&nbsp;下&nbsp;C++程序的异常处理技巧
- C\C++代码优化的27个建议
- C++游戏程序优化
- C\C++代码优化的27个建议
- .NET程序的性能要领和优化建议
- C\C++代码优化的27个建议
- [C++] C++ 对cin类中的浅 解析。希望对大家有帮助