软件延时:(asm)
晶振12MHZ,延时1秒
程序如下:
DELAY:MOV
72H,#100
LOOP3:MOV
71H,#100
LOOP1:MOV
70H,#47
LOOP0:DJNZ
70H,LOOP0
NOP
DJNZ
71H,LOOP1
MOV
70H,#46
LOOP2:DJNZ
70H,LOOP2
NOP
DJNZ
72H,LOOP3
MOV
70H,#48
LOOP4:DJNZ
70H,LOOP4
定时器延时:
晶振12MHZ,延时1s,定时器0工作方式为方汪梁坦式1
DELAY1:MOV
R7,#0AH
晶振12MHZ,延时0.5秒
AJMP
DELAY
DELAY2:MOV
R7,#14H
晶振12MHZ,延时1秒
DELAY:CLR
EX0
MOV
TMOD,#01H
设置定时器的工作方式为方式1
MOV
TL0,#0B0H
给定时器设置计数初始渣梁值
MOV
TH0,#3CH
SETB
TR0
开启定时器
HERE:JBC
TF0,NEXT1
SJMP
HERE
NEXT1:MOV
TL0,#0B0H
MOV
TH0,#3CH
DJNZ
R7,HERE
CLR
TR0
定时器要软件清零
SETB
EX0
RET
C语言延时程序:
10ms延时子程序(12MHZ)
void
delay10ms(void)
{
unsigned
char
i,j,k
for(i=5i>0i--)
for(j=4j>0j--)
for(k=248k>0k--)
}
1s延时子程序(12MHZ)
void
delay1s(void)
{
unsigned
char
h,i,j,k
for(h=5h>0h--)
for(i=4i>0i--)
for(j=116j>0j--)
for(k=214k>0k--)
}
200ms延时子程序(12MHZ)
void
delay200ms(void)
{
unsigned
char
i,j,k
for(i=5i>0i--)
for(j=132j>0j--)
for(k=150k>0k--)
}
500ms延时子程序程序:
(12MHZ)
void
delay500ms(void)
{
unsigned
char
i,j,k
for(i=15i>0i--)
for(j=202j>0j--)
for(k=81k>0k--)
}
下面是用了8.0000MHZ的晶振的几个延时程序(用定时0的工作模式1):
(1)延时0.9MS
void
delay_0_9ms(void)
{
TMOD=0x01
/*定时器0工作在模式1下(16位计数器)*/
TH0=0xfd
TL0=0xa8
TR0=1
/*启动定时困桐器*/
while(TF0==0)
TR0=0
}
(2)延时1MS
void
delay_1ms(void)
{
TMOD=0x01
/*定时器0工作在模式1下(16位计数器)*/
TH0=0xfd
TL0=0x65
TR0=1
/*启动定时器*/
while(TF0==0)
TR0=0
}
(3)延时4.5ms
void
delay_4_5ms(void)
{
TMOD=0x01
/*定时器0工作在模式1下(16位计数器)*/
TH0=0xf4
TL0=0x48
TR0=1
/*启动定时器*/
while(TF0==0)
TR0=0
}
在C语言中使用有参延时函数时,需要考虑以下几点:参数的类型和范围:延时函数的参数应该是一个整数或者长整型,代表延时的时间,通常以毫秒为单位计算。需要注意的是,参数值过大会导致程序卡死,参数值过小则可能导致延时不够精准。
多任务环境下的使用:在多任务环境下,使用延时函数可能会导致系统的调度产生问题,因此需要特别小心。在多任务系统中,延时 *** 作可以使用 *** 作系统提供的定时器来实改御现。
与硬件相关的问题:延时函数的精准度和准确性受到硬件环境的影响,特别是与CPU时钟频率和计时器相关的外设。在不同的硬件平台上,延时函数的实现方式与精准度也可能不同。
不要或陪在主循环中使用:由于延时函数的特性,它会阻塞当前的执行并延迟一段时间,因此不应该在核团岩主循环中使用。在主循环中使用延时函数会导致程序失去响应,无法处理其他任务或事件。
可移植性问题:延时函数的实现方式不同,可能会对程序的可移植性产生影响,并可能需要进行特殊的处理。因此,在使用延时函数时,需要考虑到程序的可移植性问题。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)