keil里面while循环条件已经为假了,可是跳不出去的问题

1、背景

笔者把公司里面很古老的一套程序从IAR的编译环境移植到KEIL环境下,启动文件等问题全部都解决了,能正常编译了。但是卡在了一个while(send_flag)的一个循环里面。send_flag,是中断里面的一个发送完成标志,在中断里面,发送完成后,该标志位在中断里面置0,可是退出中断后,在变量观察窗口send_flag已经变成了0了,可是程序就是跳不出去。卡死在while循环。

2、原因

在IAR编译环境下,可能对于易变化的状态标志,默认加入了volatile标志。而在keil下面是没有在变量前面加这个关键字的。keil编译环境相对更为严谨。

send_flag变量定义加上volatile就可以了。

在你进入循环的时候,实际上是将send_flag从内存加载到寄存器里面运行的,在整个循环中,send_flag这个变量都只是在读取寄存器里面的值。
当进入中断的时候,中断里面会从内存加载send_flag到寄存器,修改完之后又存到内存里,然后退出中断,再回到循环里面。但这个时候循环里使用的send_flag并没有重新从内存加载send_flag这个变量,所以一直都在循环里面。
而你在watch里面看到的send_flag变量,是通过调试接口读取对应的内存空间的,所以watch里面看到的值已经被修改了。

3、结论

写程序还是要严谨,这样可移植性会更好。不会因为一些耍小聪明的做法导致程序大了出现各种莫名其妙的问题。

你可能感兴趣的:(C/C++,STM32)