简单单片机程序延时函数
[p=175, null, left]void delay200ms(void)[p=175, null, left]void delay200ms(void) void delays(void)
{
unsigned char i,j;
for(i=0;i<100;i++)
for(j=0;j<200;j++) ;
}
粗略计算该延时函数的时间是不是100*200*1=20000uS=20mS=0.02S。如果不是,那该怎么计算,为什么,只是粗略计算。
更正:
单片机晶振是12MHz,延时函数如下:
void delays(void)
{
unsigned char i,j;
for(i=0;i<100;i++)
for(j=0;j<200;j++) ;
}
粗略计算该延时函数的时间是不是100*200*1=20000uS=20mS=0.02S。如果不是,那该怎么计算,为什么,只是粗略计算。
干嘛要自己写延时呢,编译器会提供官方的延时函数,比自己写的精确多了
單片機延時的幾種方法
1)空操作延時 (12MHz)
void delay10us()
{
_NOP_();
_NOP_();
_NOP_();
_NOP_();
_NOP_();
_NOP_();
}
2)循環延時 (12MHz)
Void delay500ms()
{
unsigned char i,j,k;
for(i=15;i>0;i--)
for(j=202;j>0;j--)
for(k=81;k>0;k--);
}
延時總時間=[(k*2+3)*j+3]*i+5
k*2+3=165 us
165*j+3=33333 us
33333*i+5=500000 us=500 ms
3)計時器中斷延時(工作方式2) (12MHz)
#include<reg52.h>
sbit led=P1^0;
unsigned int num=0;
void main()
{
TMOD=0x02;
TH0=6;
TL0=6;
EA=1;
ET0=1;
TR0=1;
while(1)
{
if(num==4000)
{
num=0;
led=~led;
}
}
}
void T0_time() interrupt 1
{
num++;
}
4)C程序嵌入組合語言延時
#pragma asm
……
組合語言程序段
……
#pragma endasm
KEIL軟件仿真測量延時程序延時時間
這是前段事件總結之延時程序、由於不懂組合語言,故NO.4無程序。希望對你有幫助!
是啊,有官方的参考
“延時總時間=[(k*2+3)*j+3]*i+5”这个是怎么得来的啊。
可以用keil仿真下啊
7楼正解!小编可以试试!
来学习下
對於12MHz晶振,機器周期為1uS,在執行該for循環延時程式的時候
Void delay500ms()
{
unsigned char i,j,k;
for(i=15;i>0;i--)
for(j=202;j>0;j--)
for(k=81;k>0;k--);
}
賦值需要1個機器周期,跳轉需要2個機器周期,執行一次for循環的空操作需要2個機器周期,那么,對於第三階循環 for(k=81;k>0;k--);,從第二階跳轉到第三階需要2機器周期 ,賦值需要1個機器周期,執行81次則需要2*81個機器周期,執行一次二階for循環的事件為81*2+1+2;執行了220次,則(81*2+3)*220+3,執行15次一階循環,則 [(81*2+3)*220+3]*15,由於不需要從上階跳往下階,則只加賦值的一個機器周期,另外進入該延時子函數和跳出該函數均需要2個機器周期,故還需要+5。希望對你有所幫助。
有点明白,非常感谢。
相互學習!
unsigned char i,j,k;这条语句需要3个机器周期还是一个机器周期,另外进函数和出函数各自需要2个机器周期还是加在一起需要2个,最后的+5不太理解
unsigned char i,j,k;用一個機器周期,+上進出函數的2*2個機器周期,則最好需+5個機器周期的時間。希望對你有幫助。
進函數需要2個機器周期,跳出函數也需要2個機器周期。
谢谢分享!
仿真才是硬道理。
非常好,谢谢分享。
学到东西了!