对于51定时器,却是有点少,有时候不经意间就被用完了,而实现定时又TM神坑了!一般的解决方案有直接上汇编,一条语句的执行时间就是一个机器周期,所以多写几个就实现了完美的定时功能。可是可是……..又有多少学51的会汇编呢?呵呵哒
所以来分享一个神好用的方法,C语言的while和nop结合使用实现精确延时
上调试代码:
#include <reg52.h>
#include <intrins.h>//声明_nop_()函数
#define TIME 164//此处是需要不断调节的改变时间的数值
//164是少4个机器周期,165是多了2个机器周期
/* ∵晶振=12MHz ∴一条指令用时=1/(12/12)=10^(-6)s=1us */
//想办法补偿,而不是减少
void delay1ms(void)
{
char i=TIME;
while(i--);
// _nop_(); //一个nop一个机器周期
// _nop_();
// _nop_();
// _nop_(); //还少4个机器周期,所以加上4个nop补偿一?
}
int main()
{
while(1)
{
delay1ms();
P1=0;
}
}
①设置软件的晶振值(12M为例)
先看164
②进入debug查看TIME分别为164、165的值
很明显164的时候差了4个机器周期
来看165
可以看出除了1ms还多出了2个机器周期
拿164补偿
补偿4个nop,刚好就是4个机器周期
okay,到此结束完毕!
PS:注意一些小问题,比如你重新改了数值之后要记得重新编译一下