OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 27899|回复: 21

keil优化级别不同,居然会差那么大?

[复制链接]

23

主题

72

帖子

0

精华

高级会员

Rank: 4

积分
735
金钱
735
注册时间
2015-7-9
在线时间
135 小时
发表于 2015-11-19 10:29:34 | 显示全部楼层 |阅读模式
昨天搞了个程序,使用优化level 3,结果编译出来在主界面上正常,进入另一个函数界面后居然会出现意想不到的效果,本来正常的刷屏变成了闪烁的,有时直接死掉,因为程序是FM的界面,连FM也会卡卡声,开始还以为是硬件问题,FM输出音频带不动。后来放着,又搞了一个界面,这个界面也不正常了,出现了同样问题,然后fm那个界面又正常了,无语中。。。。。。然后重新选了下优化级别,结果都正常了,,,晕死,,有没有同样问题的?
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

70

主题

6761

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
13118
金钱
13118
注册时间
2012-11-26
在线时间
3813 小时
发表于 2018-7-12 09:59:24 | 显示全部楼层
学无止境
回复 支持 1 反对 0

使用道具 举报

13

主题

296

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2066
金钱
2066
注册时间
2012-5-26
在线时间
291 小时
发表于 2015-11-19 10:35:01 | 显示全部楼层
我用IAR,没有用过代码优化
活着才是王道!健康是一切的前提!
回复 支持 反对

使用道具 举报

70

主题

6761

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
13118
金钱
13118
注册时间
2012-11-26
在线时间
3813 小时
发表于 2015-11-19 10:51:47 | 显示全部楼层
说明你代码有漏洞,优化低的时候不会出问题,一旦优化高,就会表现出来
学无止境
回复 支持 反对

使用道具 举报

70

主题

6761

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
13118
金钱
13118
注册时间
2012-11-26
在线时间
3813 小时
发表于 2015-11-19 10:52:10 | 显示全部楼层
不是C语言高手,建议不要开优化
学无止境
回复 支持 反对

使用道具 举报

18

主题

422

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1139
金钱
1139
注册时间
2014-5-24
在线时间
116 小时
发表于 2015-11-19 10:58:56 | 显示全部楼层
是的,优化对速度的提升是指数级的,但同时要求代码非常严谨。
I See Fire.·.·.·.·.·.·.·.·.·.·.·.·.·.·.·.·.·.·.·.  只给方向,不妨碍思考
回复 支持 反对

使用道具 举报

23

主题

72

帖子

0

精华

高级会员

Rank: 4

积分
735
金钱
735
注册时间
2015-7-9
在线时间
135 小时
 楼主| 发表于 2015-11-19 11:04:50 | 显示全部楼层
回复【3楼】jermy_z:
---------------------------------
涨姿势了,现在改好了!
回复 支持 反对

使用道具 举报

14

主题

1592

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
2622
金钱
2622
注册时间
2014-7-17
在线时间
350 小时
发表于 2015-11-21 00:46:11 | 显示全部楼层
回复【6楼】wgui:
---------------------------------
是什么问题啊???
回复 支持 反对

使用道具 举报

23

主题

72

帖子

0

精华

高级会员

Rank: 4

积分
735
金钱
735
注册时间
2015-7-9
在线时间
135 小时
 楼主| 发表于 2015-11-21 22:26:41 | 显示全部楼层
回复【7楼】FantaSy_:
---------------------------------本来是调用函数出错的,改掉代码的处理方式就好了呀!
回复 支持 反对

使用道具 举报

14

主题

1592

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
2622
金钱
2622
注册时间
2014-7-17
在线时间
350 小时
发表于 2015-11-22 16:11:48 | 显示全部楼层
回复【8楼】wgui:
---------------------------------
哦哦。。。。。
回复 支持 反对

使用道具 举报

3

主题

18

帖子

0

精华

初级会员

Rank: 2

积分
93
金钱
93
注册时间
2015-5-27
在线时间
11 小时
发表于 2016-1-5 16:53:06 | 显示全部楼层
有,今天在优化级别3下使用while(1)循环,与在优化级别0下使用while(1)循环效果就是不一样,优化级别0就好使,3根本用不了,在3中我用的for(;;)代替的while(1)结果好使
回复 支持 反对

使用道具 举报

43

主题

326

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2240
金钱
2240
注册时间
2014-10-20
在线时间
376 小时
发表于 2016-1-5 17:08:13 | 显示全部楼层
优化这个问题真是很难捉摸,之前用Tasking编程,添加了一个只用于监测的变量,结果被优化掉了,搞了好久才明白,原来没被程序使用过的变量会直接被优化掉。。。
回复 支持 反对

使用道具 举报

160

主题

967

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2097
金钱
2097
注册时间
2014-3-7
在线时间
491 小时
发表于 2018-7-12 09:57:03 | 显示全部楼层
jermy_z 发表于 2015-11-19 10:52
不是C语言高手,建议不要开优化

保守的话,优化等级选几比较好
回复 支持 反对

使用道具 举报

160

主题

967

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2097
金钱
2097
注册时间
2014-3-7
在线时间
491 小时
发表于 2018-7-12 10:34:19 | 显示全部楼层

我在网上找资料看到如下,平常的话我们默认应该是0,如果选择1的话消除死码的话,应该不会出问题吧?


0级优化:
1、 常数折叠:只要有可能,编译器就执行将表达式化为常数数字的计算,其中包括运行地址的计算。
2、 简单访问优化:对8051系统的内部数据和位地址进行访问优化。
3、 跳转优化:编译器总是将跳转延至最终目标上,因此跳转到跳转之间的命令被删除。
1级优化:
1、 死码消除:无用的代码段被消除。
2、 跳转否决:根据一个测试回溯,条件跳转被仔细检查,以决定是否能够简化或删除。
回复 支持 反对

使用道具 举报

70

主题

6761

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
13118
金钱
13118
注册时间
2012-11-26
在线时间
3813 小时
发表于 2018-7-12 10:49:22 | 显示全部楼层
ssssssssssss 发表于 2018-7-12 10:34
我在网上找资料看到如下,平常的话我们默认应该是0,如果选择1的话消除死码的话,应该不会出问题吧?

...

除了芯片资源不够了(比如ROM不足)开优化,其余时间不建议开优化
学无止境
回复 支持 反对

使用道具 举报

7

主题

185

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2729
金钱
2729
注册时间
2015-12-27
在线时间
469 小时
发表于 2018-7-12 10:54:11 | 显示全部楼层
优化等级是level0和default是同一个级别吗?level0是不是不优化?
回复 支持 反对

使用道具 举报

160

主题

967

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2097
金钱
2097
注册时间
2014-3-7
在线时间
491 小时
发表于 2018-7-12 11:23:39 | 显示全部楼层
钩月黄昏 发表于 2018-7-12 10:54
优化等级是level0和default是同一个级别吗?level0是不是不优化?

0 好像就是默认的,没优化
回复 支持 反对

使用道具 举报

49

主题

341

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
5265
金钱
5265
注册时间
2012-8-25
在线时间
1025 小时
发表于 2018-7-13 07:58:26 | 显示全部楼层
一直强迫症最高优化路过。遇到过double给double赋值出错,最后用memcpy解决。
捕获.PNG
回复 支持 反对

使用道具 举报

1

主题

4

帖子

0

精华

新手上路

积分
36
金钱
36
注册时间
2019-4-30
在线时间
9 小时
发表于 2019-6-18 11:26:43 | 显示全部楼层

我都是默认最高优化,速度提升很明显。单片机本身就不快,开优化能提升性能。
回复 支持 反对

使用道具 举报

0

主题

14

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
205
金钱
205
注册时间
2019-4-11
在线时间
17 小时
发表于 2019-6-18 21:30:37 | 显示全部楼层
ssssssssssss 发表于 2018-7-12 10:34
我在网上找资料看到如下,平常的话我们默认应该是0,如果选择1的话消除死码的话,应该不会出问题吧?

...

感谢科普
回复 支持 反对

使用道具 举报

2

主题

6

帖子

0

精华

新手上路

积分
24
金钱
24
注册时间
2020-6-12
在线时间
5 小时
发表于 2020-7-16 17:25:29 | 显示全部楼层
我也碰到了,优化级别不同,程序运行就会出问题,找了半天,还以为是程序问题,吐血.
回复 支持 反对

使用道具 举报

33

主题

984

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8024
金钱
8024
注册时间
2014-8-13
在线时间
1595 小时
发表于 2020-7-16 17:52:51 | 显示全部楼层
telentmmc 发表于 2016-1-5 17:08
优化这个问题真是很难捉摸,之前用Tasking编程,添加了一个只用于监测的变量,结果被优化掉了,搞了好久才 ...

volatile关键字了解一下
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-10 10:20

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表