帮忙看一下keil开优化后程序出现运行异常的问题

2019-12-11 18:27发布

本帖最后由 NIC 于 2019-5-6 08:52 编辑

原来是level0,改为level 1后,具体代码如下,反汇编如图所示,       
                        if(CtrlSignFlag==1)
                        {
                                CtrlSignFlag++;
                                if(CtrlSignCet >=30)
                                {
                                        CtrlSignCet =0;
                                        if(CtrlSignStu.CtrlSignTask[0] == 1)
                                        {
                                                CtrlSignFlag =0;               
                                                CtrlActinter=30;
                                  }
                                }
                        }               
代码运行后, if(CtrlSignFlag==1)不成立的情况下直接跳转到 if(CtrlSignStu.CtrlSignTask[0] == 1) 这条语句,从反汇编代码也可以看出是直接执行到这条语句了,跟源代码对比一下大家就会发现我指的问题所在,但不知道编译器为什么会这样优化

我再把优化等级为level0时的反汇编代码发一下,比对一下就知道与level1时的明显区别,第一张图是优化等级level1,第二张图是优化等级level0
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
13条回答
NIC
1楼-- · 2019-12-11 22:58
有沒有大神指点一下
Name_006
2楼-- · 2019-12-12 02:07
有没有其他地方  有这一句?  如果有的话是不是把两个地方的这一句合并成一个地方了
if(CtrlSignStu.CtrlSignTask[0] == 1)
                                        {
                                                CtrlSignFlag =0;               
                                                CtrlActinter=30;
                                  }
vuo50z
3楼-- · 2019-12-12 03:44
没错啊,不成立跳转到688a
NIC
4楼-- · 2019-12-12 06:27
Name_006 发表于 2019-5-5 21:29
有没有其他地方  有这一句?  如果有的话是不是把两个地方的这一句合并成一个地方了
...

没有,看反汇编代码,除了直接跳转到 if(CtrlSignStu.CtrlSignTask[0] == 1) 这条语句这个问题,还有编译器对这几行代码为什么会重复两次执行
if(CtrlSignFlag==1)
                        {
                                CtrlSignFlag++;
                                if(CtrlSignCet >=30)
NIC
5楼-- · 2019-12-12 09:16
 精彩回答 2  元偷偷看……
gliet_su
6楼-- · 2019-12-12 14:24
debug打个断点,如果那里不能打断点就是被优化了

一周热门 更多>