不用定时器和汇编语言,只用C语言实现精确无误的延时

时间:2021-08-29 01:10:30

对于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

不用定时器和汇编语言,只用C语言实现精确无误的延时

②进入debug查看TIME分别为164、165的值
不用定时器和汇编语言,只用C语言实现精确无误的延时
不用定时器和汇编语言,只用C语言实现精确无误的延时

很明显164的时候差了4个机器周期

来看165
不用定时器和汇编语言,只用C语言实现精确无误的延时
不用定时器和汇编语言,只用C语言实现精确无误的延时
可以看出除了1ms还多出了2个机器周期

拿164补偿
补偿4个nop,刚好就是4个机器周期

不用定时器和汇编语言,只用C语言实现精确无误的延时

okay,到此结束完毕!

PS:注意一些小问题,比如你重新改了数值之后要记得重新编译一下