程序优化的几个建议

时间:2022-04-03 05:06:32 阅读: 最新文章 文档下载
说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。


(1

)

本页仅作为文档封面,使用时可以删除

This document is for reference only-rar21year.March


给出程序优化的几个建议,希望对你有帮助

如何写出高性能的C/C++代码一直是hack追求的境界,这里总结了一些常用的,希望对大家有用,欢迎拍砖,给出建议。

第一:记住,代码写完后一定要做一下系统优化,无论上面是否这样要求,但是这点很重要,是一种态度,当然优化可以借助各种工具如IBMINTEL系列的优化工具,一般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一下。综合考虑空间和时间上的效率


本文来源:https://www.wddqw.com/doc/b6ce5176d3f34693daef5ef7ba0d4a7302766cac.html