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

对于51定时器,却是有点少,有时候不经意间就被用完了,而实现定时又TM神坑了!一般的解决方案有直接上汇编,一条语句的执行时间就是一个机器周期,所以多写几个就实现了完美的定时功能。可是可是……..又有多少学51的会汇编呢?呵呵哒

所以来分享一个神好用的方法,C语言的while和nop结合使用实现精确延时

上调试代码:

#include   
#include //声明_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语言实现精确无误的延时_第1张图片

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

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

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

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

不用定时器和汇编语言,只用C语言实现精确无误的延时_第6张图片

okay,到此结束完毕!

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

你可能感兴趣的:(#,单片机,c语言,单片机)