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日



http://blog.sciencenet.cn/blog-1005104-727037.html    此文来自科学网刘传武博客,转载请注明出处。
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、选择合适的算法和数据结构 2、使用尽量小的数据类型 3、减少运算的强度 (1)查表 (2)求余运算 (3)平方运算 (4)用移位实现乘除法运算 (5)避免不必要的整数除法 (6)使用增量和减量操作符 (7)使用复合赋值表达式 (8)提取公共的子表达式 4、结构体成员的布局 (1)按数据类型的长度排序 (2)把结构体填充成最长类型长度的整倍数 (3)按数据类型的长度排序本地变量 (4)把频繁使用的指针型参数拷贝到本地变量 5、循环优化 (1)充分分解小的循环 (2)提取公共部分 (3)延时函数 (4)while循环和do…while循环 (5)循环展开 (6)循环嵌套 (7)Switch语句中根据发生频率来进行case排序 (8)将大的switch语句转为嵌套switch语句 (9)循环转置 (10)公用代码块 (11)提升循环的性能 (12)选择好的无限循环 6、提高CPU的并行性 (1)使用并行代码 (2)避免没有必要的读写依赖 7、循环不变计算 8、函数 (1)Inline函数 (2)不定义不使用的返回值 (3)减少函数调用参数 (4)所有函数都应该有原型定义 (5)尽可能使用常量(const) (6)把本地函数声明为静态的(static) 9、采用递归 10、变量 (1)register变量 (2)同时声明多个变量优于单独声明变量 (3)短变量名优于长变量名,应尽量使变量名短一点 (4)在循环开始前声明变量 11、使用嵌套的if结构
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值