51单片机汇编延时程序算法详解.doc

上传人:白大夫 文档编号:3244857 上传时间:2019-08-05 格式:DOC 页数:3 大小:17.50KB
返回 下载 相关 举报
51单片机汇编延时程序算法详解.doc_第1页
第1页 / 共3页
亲,该文档总共3页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《51单片机汇编延时程序算法详解.doc》由会员分享,可在线阅读,更多相关《51单片机汇编延时程序算法详解.doc(3页珍藏版)》请在三一文库上搜索。

1、51单片机汇编延时程序算法详解将以12MHZ晶振为例,详细讲解MCS-51单片机中汇编程序延时的精确算法。指令周期、机器周期与时钟周期指令周期:CPU执行一条指令所需要的时间称为指令周期,它是以机器周期为单位的,指令不同,所需的机器周期也不同。时钟周期:也称为振荡周期,一个时钟周期 =晶振的倒数。MCS-51单片机的一个机器周期=6个状态周期=12个时钟周期。MCS-51单片机的指令有单字节、双字节和三字节的,它们的指令周期不尽相同,一个单周期指令包含一个机器周期,即12个时钟周期,所以一条单周期指令被执行所占时间为12*(1/12000000)=1s。扩展阅读:单片机有哪些延时方法详细介绍程

2、序分析例1 50ms 延时子程序:DEL:MOV R7,#200 DEL1:MOV R6,#125 DEL2:DJNZ R6,DEL2 DJNZ R7,DEL1 RET 精确延时时间为:1+(1*200)+(2*125*200)+(2*200)+2=(2*125+3)*200+3 =50603s50ms由整理出公式(只限上述写法)延时时间=(2*内循环+3)*外循环+3 详解:DEL这个子程序共有五条指令,现在分别就 每一条指令 被执行的次数和所耗时间进行分析。第一句:MOV R7,#200 在整个子程序中只被执行一次,且为单周期指令,所以耗时1s第二句:MOV R6,#125 从看到只要R7

3、-1不为0,就会返回到这句,共执行了R7次,共耗时200s第三句:DJNZ R6,DEL2 只要R6-1不为0,就反复执行此句(内循环R6次),又受外循环R7控制,所以共执行R6*R7次,因是双周期指令,所以耗时2*R6*R7s。例2 1秒延时子程序:DEL:MOV R7,#10 DEL1:MOV R6,#200 DEL2:MOV R5,#248 DJNZ R5,$ DJNZ R6,DEL2 DJNZ R7,DEL1 RET 对每条指令进行计算得出精确延时时间为:1+(1*10)+(1*200*10)+(2*248*200*10)+(2*200*10)+(2*10)+2=(2*248+3)*2

4、00+3*10+3 =998033s1s由整理得:延时时间=(2*第一层循环+3)*第二层循环+3*第三层循环+3 此式适用三层循环以内的程序,也验证了例1中式(第三层循环相当于1)的成立。注意,要实现较长时间的延时,一般采用多重循环,有时会在程式序里加入NOP指令,这时公式不再适用,下面举例分析。例3仍以1秒延时为例DEL:MOV R7,#10 1指令周期1DEL1:MOV R6,#0FFH 1指令周期10DEL2:MOV R5,#80H 1指令周期255*10=2550KONG:NOP 1指令周期128*255*10=326400DJNZ R5,$ 2指令周期2*128*255*10=652800DJNZ R6,DEL2 2指令周期2*255*10=5110DJNZ R7,DEL1 2指令周期2*10=20RET 2延时时间=1+10+2550+326400+652800+5110+20+2 =986893s约为1s整理得:延时时间=(3*第一层循环+3)*第二层循环+3*第三层循环+3 结论:针对初学者的困惑,对汇编程序的延时算法进行了分步讲解,并就几种不同写法分别总结出相应的计算公式,只要仔细阅读例1中的详解,并用例2、例3来加深理解,一定会掌握各种类型程序的算法并加以运用。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1