第3章-MCS-51单片机指令系统-3.5汇编语言程序基本结构.pptVIP

第3章-MCS-51单片机指令系统-3.5汇编语言程序基本结构.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
3.5 汇编语言程序的基本结构;程序框架;NAME EQU R1 NUM DATA 30H P10 BIT P1.0 ORG 0000H LJMP MAIN ;跳转至主程序 ORG 0003H LJMP INT0_INT ;跳转至中断服务程序 ORG 0030H MAIN: … ;开始写主程序 SJMP $ PRO1: … RET INT0_INT: … RETI TAB: DB 00H, 01H, 02H DB 03H, 04H END;3.5 汇编语言程序的基本结构;;3.5.1 顺序程序设计 ; ;设R0为数据指针 ;取X1 ;X1+X2 ;保存结果 ;[例3] 功能:单字节压缩BCD码转换成二进制码 入口:R2 = 待转换压缩BCD码 出口:R2 = 转换结果;[例4] 功能:两个无符号双字节数相加 入口: 被加数存在内RAM 31H(高位字节)、30H(低位字节) 加数存放在内RAM 41H(高位字节)、40H(低位字节) 出口:和存入内RAM 31H(高位字节)、30H(低位字节);3.5.2 分支程序设计;ORG 0000H  ST1 EQU 2000H ST2 EQU 2100H ST3 EQU 2200H STA: MOV DPTR, #ST1 ;第一个数的指针 MOVX A, @DPTR ;取第一个数 MOV R2, A ;保存 MOV DPTR, #ST2 ;第二个数的指针 MOVX A, @DPTR ;取第二个数 CLR C ;清零Cy SUBB A, R2 ;两数比较 JNC BIG0 ;若第二个数大, 则转 XCH A, R2 ;第一个数大 BIG0: MOV DPTR, #ST3  MOVX @DPTR, A ;存大数 SJMP $ END;ORG 0000H  ST1 EQU 2000H ST2 EQU 2100H ST3 EQU 2200H STA: MOV DPTR, #ST1 ;第一个数的指针 MOVX A, @DPTR ;取第一个数 MOV R2, A ;保存 MOV DPTR, #ST2 ;第二个数的指针 MOVX A, @DPTR ;取第二个数 CLR C ;清零Cy PUSH ACC ;保存原值 SUBB A, R2 ;两数比较 POP ACC ;恢复原值 NEXT: JNC BIG0 ;若第二个数大, 则转 XCH A, R2 ;第一个数大 BIG0: MOV DPTR, #ST3  MOVX @DPTR, A ;存大数 SJMP $ END;2. 多分支程序 一般多分支、散转多分支 (1)一般多分支 [例1]x、y均为8位二进制数,求解: 入口:(R0)= x 出口:(R1)= y;P82:一般多分支[例]纠错;奉吹旅钩迅阴拇欲白玲塔蕴敲趟巢默萎派较们阻徽衰办吧子矗杀暂扫赎递第3章-MCS-51单片机指令系统-3.5汇编语言程序的基本结构第3章-MCS-51单片机指令系统-3.5汇编语言程序的基本结构;3.5.3 循环程序设计;(a)先执行后判断 (b)先判断后执行 图3.12 循环程序框图;[例1] 单重循环;[例2] 内部 RAM ADDR 为起始地址的数据块内数据是无符号数,块长在 LEN 内。编程求数据块的最大值。 入口:(ADDR)= 起始地址;(LEN)= 长度 出口:(MAX)= 最大值;[例3] 软件延时程序(P85); MOV R1, #200 DELAY: MOV R0, #0FAH ;R0=250 LOOP: MOV R7, #70H DJNZ R0, LOOP DJNZ R1, DELAY;[例4] 双重循环;ORG 2000H 指令机器周期数 MOV R0 , #0AH ;毫秒数→R0 1 DL2: MOV R1 , #MT ;1ms延时值→R1 1 DL1: NOP 1 NOP 1 DJNZ R1 , DL1 ;1ms延时循环 2 DJNZ R0 , DL2 ;10ms延时循环 2 END;[例5] 多重循环;3.5.4 子程序设计;[例

文档评论(0)

sy78219 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档