单片机while(--t)延时计算(KEIL调试解读)

先贴上程序

#include
#define uchar unsigned char
void Delay(uchar);
//主程序
void main()
{
  while(1)
  {
    Delay(10);//调用延时
  }

}
//延时子程序
void Delay(uchar t)
{
  while(--t);
}

这个延时程序由来已久,它的延时可以被精确计算。先来看看这段程序的反汇编代码,延时程序的调用就是按图中顺序来执行的。
解读:
C:0x000F 指令地址
7F0A 指令的二进制编码(参考单片机指令系统)
MOV R7, #0x0A 指令内容

单片机while(--t)延时计算(KEIL调试解读)_第1张图片

1.参数传递(MOV,1机器周期,相关内容参考指令系统)
2.长调用(LCALL,2机器周期)
3.函数体(循环执行 DJNZ t次,每次2机器周期)
4.子程序返回(RET,2机器周期)

执行一条指令的时间,定义为指令周期。每条指令可能分若干步骤完成,每个步骤定义为一个基本操作,一个基本操作的时间定义为机器周期。
一个机器周期占用6个状态周期(参考《微机原理与接口技术》),每个状态周期占用2个时钟周期。
一个时钟周期=1/晶振频率。以12M晶振为例,一个时钟周期Tc=1/12 微秒。
总延时T=(1+2+2*t+2)*12*Tc=12*Tc*(2*t+5) us.

以上计算都是基于传统8051单片机系统。
现在的8051单片机在汇编指令执行效率方面有很大改进,取消了机器周期的概念,指令执行均以时钟周期来计量。
比如下图,截取的是STC15系列单片机与传统8051单片机指令耗时的对比数据。以MOV Rn,#data 为例,传统8051耗时12时钟,而STC只用2个时钟周期就完成了指令。
因此,对于延时的计算,不同的单片机会有不同的结果。

另外,while(t--)while(--t)的延时是完全不同的,同一单片机,前者的延时大于后者。

单片机while(--t)延时计算(KEIL调试解读)_第2张图片

你可能感兴趣的:(单片机)