liuchuanwu的个人博客分享 http://blog.sciencenet.cn/u/liuchuanwu

博文

C语言程序代码优化

已有 6915 次阅读 2013-9-22 23:36 |个人分类:C语言|系统分类:科研笔记| C语言, 优化, 代码, 程序

我认为一个好的用于科学计算的程序代码应该:算法漂亮精妙,程序简洁易懂,运算快速,节省内存。这里有的地方是矛盾的,比如简洁vs易懂,时间vs空间,找个平衡吧。目前来看时间要比空间宝贵一些。写程序分几步:选择最妙的算法;规划最优的流程;规划数据结构、函数;编码实现。以下是查找网上资料后的总结。


一、好的方法、算法和数据结构是程序优化的根本,选择最好的算法永远是王道。


二、规划流程时几个不依赖于编译器的tips:

1、减少运循环体内运算量:

(a),查表:提前列表,循环内查表。

(b),提取循环的公共子式到循环外计算。

(c),将循环体展开以减少循环的判断过程。

2、判断式合理排列conditions减少判断次数:

(a),根据发生频率排列switch语句的case,或者if语句的条件式。

(b),将一些低概率条件合并及嵌套判断。

(c),将多重条件嵌套判断。

3、合理组织循环和判断的嵌套

(a),将值不变的条件式放在循环的外面。


三、C语言设计数据结构的tips.

1,使用尽量小的数据结构。如char好于int好于float。

2,使用便于运算的数据结构。

3,数据合理布局

(a)结构体数据成员按类型长度排序。

(b)把结构体填充成最长类型长度的整数倍。

4,变量名短好于长。

5,同时声明变量好于分别声明变量


四,C语言数据操作的tips。

1,使用指针。

2,尽量使用常量。

3,常用变量设置为寄存器变量。

4,初始化好于赋值。

5,减少文件读取操作。


五,C语言数据运算强度的优化,即使用快的运算代替慢的运算。

1,使用位运算。

2,用a*a代替pow(a,2.0)。

3,减少整数除法,如用i/(j*k)代替i/j/k。


六,C语言函数优化。

1,函数用inline代替外部调用(但会增加程序长度)。

2,定义函数原型,便于编译器优化。

3,不定义不使用的返回值。

4,本地函数声明为静态。


2013年9月23日



https://wap.sciencenet.cn/blog-1005104-727037.html

上一篇:兰大萃英班之道听途说
下一篇:C语言的位运算
收藏 IP: 128.250.55.*| 热度|

1 张忆文

该博文允许注册用户评论 请点击登录 评论 (0 个评论)

数据加载中...

Archiver|手机版|科学网 ( 京ICP备07017567号-12 )

GMT+8, 2024-4-17 02:41

Powered by ScienceNet.cn

Copyright © 2007- 中国科学报社

返回顶部