C语言的延时计算
今天碰到这个问题,想想大家也可能用得上,就转过来了,希望对大家有用
C51中精确的延时与计算的实现
C51由于其可读性和可移植性很强,在单片机中得到广泛的应用,
但在某些时候由于C51编写的程序对在有精确时间要求下,可能
就得要用汇编语言来编写,但在C51是否也能实现时间的精确控
制呢?答案是肯定的。
在C51中要实现对时间的精确延时有以下几种方法
其一:对于延时很短的,要求在us级的,采用“_nop_”函数,
这个函数相当汇编NOP指令,延时几微秒,就插入个这样的函数。
NOP指令为单周期指令,可由晶振频率算出延时时间,对于12M
晶振,延时1uS。
其二:对于延时比较长的,要求在大于10us,采用C51中的循环
语句来实现。
在选择C51中循环语句时,要注意以下几个问题
第一、定义的C51中循环变量,尽量采用无符号字符型变量。
第二、在FOR循环语句中,尽量采用变量减减来做循环。
第三、在do…while,while语句中,循环体内变量也采用减减方法。
这因为在C51编译器中,对不同的循环方法,采用不同的指令来完
成的。下面举例说明:
unsigned char I;
for(i=0;i<255;i++);
unsigned char I;
for(i=255;i>0;i–);
其中,第二个循环语句C51编译后,就用DJNZ指令来完成,相当于如下指令:
MOV 09H,#0FFH
LOOP: DJNZ 09H,LOOP
指令相当简洁,也很好计算精确的延时时间。
同样对do…while,while循环语句中,也是如此
例:
unsigned char n;
n=255;
do{n–}
while(n);
或
n=255;
while(n)
{n–};
这两个循环语句经过C51编译之后,形成DJNZ来完成的方法,
故其精确时间的计算也很方便。
其三:对于要求精确延时时间更长,这时就要采用循环嵌套
的方法来实现,因此,循环嵌套的方法常用于达到ms级的延时。
对于循环语句同样可以采