踩坑编译器优化问题
故事背景:
最近在调试自己画的板子时,又再次遇到了变量被编译器优化的问题。虽然不是第一次遇到这个问题了,但还是花了一些时间才定位到这个点。为了警醒自己,避免再在这个问题上浪费时间,特记录下来。
问题描述:
调试代码时,发现rxFlag(串口接收数据完成标志)被置起时,无法进入 if 条件语句。
问题分析:
如下图,在Debug模式下,从生成的汇编代码中可以看到,程序只对rxFlag执行了一次判断,然后就一直在0x080020E6这里了,不会再跳转到0x080020D2去取rxFlag的值做判断了。这样问题已经很明显了,可能是编译器优化了变量,并不是每次都从变量的源头去取值。所以,rxFlag变量前应加volatile关键字修饰。
问题解决:
在变量前加关键字 volatile。从下图可以看出,程序都是跳转到0x080020D6,从rxFlag源头取值。所以加关键字volatile可以解决这个问题。