您的位置 首页 嵌入式

Keil C51中的优化等级及优化效果

级别说明0常数合并:编译器预先计算结果,尽可能用常数代替表达式。包括运行地址计算。优化简单访问:编译器优化访问8051系统的内部数据和

等级阐明

0常数兼并:编译器预先核算成果,尽或许用常数替代表达式。包括运转地址核算。
优化简略拜访:编译器优化拜访8051体系的内部数据和位地址。
跳转优化:编译器总是扩展跳转到最终目标,多级跳转指令被删去。

1死代码删去:没用的代码段被删去。
回绝跳转:紧密的查看条件跳转,以确认是否能够倒置测验逻辑来改善或删去。

2数据掩盖:合适静态掩盖的数据和位段被确认,并内部标识。BL51衔接/定位器能够通

过大局数据流分,挑选可被掩盖的段。

3窥孔优化:铲除剩余的MOV指令。这包括不必要的从存储区加载和常数加载操作。当存

储空间或履行时刻可节省时,用简略操作替代杂乱操作。

4寄存器变量:如有或许,主动变量和函数参数分配到寄存器上。为这些变量保存的存储区就省掉了。
优化扩展拜访:IDATA、XDATA、PDATA和CODE的变量直接包括在操作中。在大都时刻没

必要运用中心寄存器。
部分公共子表达式删去:假如用一个表达式重复进行相同的核算,则保存第一次核算

成果,后边有或许就用这成果。剩余的核算就被删去。
Case/Switch优化:包括SWITCH和CASE的代码优化为跳转表或跳转行列。

5大局公共子表达式删去:一个函数内相同的子表达式有或许就只核算一次。中心成果

保存在寄存器中,在一个新的核算中运用。
简略循环优化:用一个常数填充存储区的循环程序被修正和优化。

6循环优化:假如成果程序代码更快和有用则程序对循环进行优化。

7扩展索引拜访优化:适其时对寄存器变量用DPTR。对指针和数组拜访进行履行速度和代码巨细优化。

8公共尾部兼并:当一个函数有多个调用,一些设置代码能够复用,因而削减程序巨细

9公共块子程序:检测循环指令序列,并转换成子程序。Cx51乃至重排代码以得到更大的循环序列。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/qianrushi/258109.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部