标签:ar sp for bs 代码 ef 时间 nbsp 程序
注:12M晶振,一周期为1us
#include<reg51.h>
main()
{
unsigned int i;
i=70;
while(i--);
}
上述程序汇编代码:
C:0x0007 EF MOV A,R7
C:0x0008 1F DEC R7
C:0x0009 AC06 MOV R4,0x06
C:0x000B 7001 JNZ C:000E
C:0x000D 1E DEC R6
C:0x000E 4C ORL A,R4
C:0x000F 70F6 JNZ C:0007
//为何此循环延时640us?因为根据汇编结果,循环一次需9个周期(如何得出?可以通过keil仿真下断点的方式得出,当然也可以直接算出,根据指令的类型来确定其运行所需周期,具体的可以搜索“指令周期”来详细了解),故70x9=630;而当最后i=0时,还要再运行一次判断为0后跳转出循环,故为630+10(为何为10?见下)=639;
//最后i为零时循环一次需10个周期,因为i不为0时语句“JNZ C:000E DEC R6"此两个语句,由于前面JNZ判断条件成立,故把后面语句跳过,而
//当i为0时,此语句不在跳过,故执行时间加一个周期;
//综上,包括”i=70“语句在内的while循环共延时了642us;
//特别注意:如果变量i的定义类型不同,延时的时间也不相同;
//比如:如果定义i为unsigned char i;那么延时的时间将只有400多us,具体原因看两种情况所产生的汇编代码即可知晓!!
//注:以上是通过keil仿真得到的结果
//通过下断点来确定一条指令或一次循环所需时间
for循环与此类似,不在赘述。
标签:ar sp for bs 代码 ef 时间 nbsp 程序
原文地址:http://www.cnblogs.com/bingley/p/4115292.html