困扰了好几天的问题,就是因为一个printf
问题:接收中断触发了,但是中断函数内的操作没有执行,这也就导致收到信号,但是函数内的flag标志位没变,相当于没中断。
为什么中断函数中不要使用printf????
需要分各种情况讨论。【按照中断函数的行为】有些中断函数为了防止中断嵌套,会将中断临时禁用【按照printf的实现方式】,有些会通过轮询方式实现,优先会通过串口中断方式实现。
1.如果中断函数中禁用了中断
如果调用的printf依赖中断打印,会造成printf无法打印
如果调用的printf通过轮询方式实现,打印一段字符的时间过长,大大降低中断处理效率,而且在中断禁用期间可能会错失很多其它中断
2.如果中断函数中没有禁用中断
printf函数执行过程中,主中断可能会再次被触发,从而再次调用printf,造成printf函数的重新进入。而很多printf函数由于调用了全局资源,是不支持可重新进入的,会造成灾难性后果。