之前在做EFM32TG的一个项目时,遇到了一个问题,while循环条件为假却还是一直在循环里面无法退出,代码如下:
/***************************************************************************//**
* @brief Delays number of msTick Systicks (typically 1 ms)
* @param dlyTicks Number of ticks to delay
******************************************************************************/
void TickDly(uint32_t dlyTicks)
{
uint32_t curTicks;
curTicks = msTicks;
while ((msTicks - curTicks) < dlyTicks) ;
}
函数功能很简单就是一个毫秒延时,变量msTick在滴答中断中每毫秒自增1。
经过查找资料和跟网友的交流谈一下自己对这个问题的理解:
当进入循环的时候,CPU是把msTick是从内存加载到寄存器中运行的,中断发生的时候同样是把msTick加载到寄存器赋值后在存到内存中,最后退出中断在回到循环中。所以msTick对应的内存值已经发生改变,但循环里面却没有重新从内存中加载变量的值导致循环里面msTick的值并没有发生改变所以无法退出循环。
解决方法就是在msTick加上volatile关键字修饰,这样编译后的程序在msTick变量发生改变的时候就会直接从变量地址中加载该变量的值。