image.png

    先上一张图,图中Req_Timer是我定义的一个变量,uint16_t Req_Timer,在定时器里面加一递增,按照流程,应该是先判断USART_RX_STA是否为真,为真就跳出while执行下一步,为假就执行if语句,判断Req_Timer是否>=0,若是则执行if里面的代码,随笔重点来了,我在仿真时发现,在Req_Time>100后,编译器并不往下执行,依然是停留在等待Req_Time>=100这条语句,卡死在此处,仿真了几次,百思不得其解,明明流程没错,怎么就是不执行。
    在百度了很多关键词后,在一个论坛中找到答案,在开中断后,while里面嵌套的IF语句判断变量不能正确判断,论坛结贴写明:在定义全局变量时,需要加上volatile关键字。

    于是我又去查找volatile关键字的用法与定义:
    volatile 影响编译器编译的结果,volatile指出 变量是随时可能发生变化的,与volatile变量有关的运算,不要进行编译优化,以免出错
    恍然大悟,也就是说在编译器编译时,因为我定义的变量在中断打开,每个5MS加一的情况下,突然在别的文件中被清零,所以编译器进行了优化,使得上面图片中的if语句不能进行正确的判断,从而引起故障。