是这样的:分支转移指令的指令(例如你程序中的LOOP和JNZ等等)的周期不是固定的一个数,而是与走哪个分支相关的,那个17
OR
5就是这个意思,以LOOP
WAIT为例,内循环中该指令共执行2801次,前2800次都会转移(17),最后一次是顺序向下执行(5),这就是2801x17-12的由来,当然也可以写成(2801-1)x17+5
另外,通常来说分支转移指令“转移”的分支周期数比“顺序”的分支要长,这是因为“转移”使得指令队列或者流水线中断了,需要重新填满。
现在CPU中的“分支预测”功能其实就是为了解决这个问题的,还以你的内循环为例,有“分支预测”时的执行时间就变成1x17+(2801-2)x5+1x17了,快了许多。
呵呵,你的理解几乎都是对的。
最后一次执行分支指令时,按预测要“跳转”,所以CPU就按跳转的顺序装入指令队列,可问题是这一次不该跳转,所以预测错了,所以事先装入的指令队列都要作废,这与没有“分支预测”时的“跳转”是一样的。也就是说,有“分支预测”时,是预测对5,预测错17。
没有“分支预测”功能“相当于”每次都“预测”不跳转,所以只有最后一次“预测”对了;而有“分支预测”功能时,预测结果和前一次执行该指令相同,所以对于循环来说,第1次会错(没有“前一次”,就按顺序预测),最后一次也会错(因为前一次跳转了而这一次不),中间的其它次都会预测正确。
明白了吗,关键不是“跳不跳转”,而是需不需要“重装”指令队列或流水线。
1、下面几个是单片机的延时程序(包括asm和C程序,都是我在学单片机的过程中用到的),在单片机延时程序中应考虑所使用的晶振的频率,在51系列的单片机中我们常用的是110592MHz和120000MHz的晶振,而在AVR单片机上常用的有8000MHz和4000MH的晶振所以在网上查找程序时如果涉及到精确延时则应该注意晶振的频率是多大。
2、软件延时:(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,延时05秒
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
3、C语言延时程序:
10ms延时子程序(12MHZ)
void
delay10ms(void)
{
unsigned
char
i,j,k;
for(i=5;i>0;i--)
for(j=4;j>0;j--)
for(k=248;k>0;k--);
}
1s延时子程序(12MHZ)
void
delay1s(void)
{
unsigned
char
h,i,j,k;
for(h=5;h>0;h--)
for(i=4;i>0;i--)
for(j=116;j>0;j--)
for(k=214;k>0;k--);
}
200ms延时子程序(12MHZ)
void
delay200ms(void)
{
unsigned
char
i,j,k;
for(i=5;i>0;i--)
for(j=132;j>0;j--)
for(k=150;k>0;k--);
}
500ms延时子程序程序:
(12MHZ)
void
delay500ms(void)
{
unsigned
char
i,j,k;
for(i=15;i>0;i--)
for(j=202;j>0;j--)
for(k=81;k>0;k--);
}
这个是循环查询定时器溢出标志位是否为一,即查询法。
ORG 00H
LJMP MAIN
ORG 30H
MAIN:
MOV TMOD,#10H
MOV TCON,#00H
MOV TL1,#78H
MOV TH1,#0ECH
SETB TR1 //启动定时器T1
LOOP:
JBC TF1,TIME1 //等待定时器溢出
SJMP LOOP
TIME1:
MOV TL1,#78H //重装初值
MOV TH1,#0ECH
SJMP LOOP
RET
END
中断法
ORG 00H
LJMP MAIN
ORG 001BH
LJMP TIME_1
ORG 30H
MAIN:
MOV TMOD,#10H
MOV TCON,#00H
MOV TL1,#78H
MOV TH1,#0ECH
SETB ET1
SETB EA
SETB TR1 //启动定时器T1
SJMP $ //等待中断,TR1置一
TIME_1:
MOV TL1,#78H //重装初值
MOV TH1,#0ECH
RETI
END
以上就是关于希望得到一道汇编程序的延时时间的解释(题目和答案都有,只是不了解)全部的内容,包括:希望得到一道汇编程序的延时时间的解释(题目和答案都有,只是不了解)、51单片机求10微秒的延时函数 C语言(晶振11.0592MHz)、51单片机用定时器T1编写延时10ms汇编程序 谁给写一个 急啊等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)