单片微机原理及应用第三章 MCS-51系列单片机的指令系统.ppt

单片微机原理及应用第三章 MCS-51系列单片机的指令系统.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第十节 数制转换 【例21】将一个字节二进制数转换成 3 位非压缩型BCD码。 设一个字节二进制数在内部RAM 40H单元, 转换结果放入内部 RAM 50H#, 51H, 52H单元中(高位在前), 程序如下: HEXBCD: MOV A, 40H MOV B, #100 DIV AB MOV 50H, A MOV A, #10 XCH A, B DIV AB MOV 51H, A MOV 52H, B RET 【例22】设 4 位BCD码依次存放在内存 RAM中 40H~43H单元的低4 位, 高 4 位都为 0, 要求将其转换为二进制数, 结果存入 R2R3 中。  一个十进制数可表示为:  Dn×10n +Dn-1×10n-1 +… + D0×100 =(…((Dn×10+Dn-1)×10+Dn-2)×10+…)+D0 当n=3时, 上式可表示为:  ((D3×10+D2)×10+D1)×10+D0 BCDHEX: MOV R0, #40H ; R0指向最高位地址 MOV R1, #03 ; 计数值送R1 MOV R2, #0 ; 存放结果的高位清零 MOV A, @R0 MOV R3, A LOOP: MOV A, R3 MOV B, #10 MULAB MOV R3, A ; (R3)×10 的低 8 位送R3 MOV A, B XCHA, R2 ; (R3)×10的高 8 位暂存R2 MOVB, #10 MUL AB ADD A, R2 MOV R2, A ; R2×10+( R3×10)高 8 位送R2 INC R0 ; 取下一个 BCD数 MOV A, R3 ADD A, @R0 MOV R3, A MOV A, R2 ADD C A, #0 ; 加低字节来的进位 MOV R2, A DJNZ R1, LOOP RET 第十一节 多分支转移(散转)程序 1. 分支程序结构 2. 一般分支程序设计 3. 分支表法实现多向分支程序的设计 条件 S1 S2 Y N 条件 S1 条件 N S2 S1 Sn … (a)单分支 (b)双分支 (c)多分支 1. 分支程序结构 【例5】 x, y均为8位二进制数, 设 x存入R0, y存入R1, 求解: 2. 一般分支程序结构实例 程序如下:  START: CJNE R0,#00H,SUL1 ; R0中的数与00比较不等转移 MOV R1, #00H ; 相等, R1← 0 SJMP SUL2  SUL1: JC NEG ; 两数不等, 若(R0)0, 转向NEG MOV R1, #01H ; (R0)0, 则 R1←01H SJMP SUL2 NEG: MOV R1, #0FFH ; (R0)0, 则 R1←0FFH SUL2: RET 【例 6 】 比较两个无符号数的大小。 设外部 RAM 的存储单元ST1和 ST2中存放两个不带符号的二进制数, 找出其中的大数存入外部 RAM 中的 ST3单元中。 程序如下: ORG 1000H  ST1 EQU 2000H ST2 EQU 2100H ST3 EQU 2200H START: CLR C ; 清零Cy MOV DPTR, #ST1 ; 第一个数的指针 MOVX A, @DPTR ; 取第一个数 MOV R2, A ; 保存 MOV DPTR, #ST2 ; 第二个数的指针 MOVX A, @DPTR ; 取第二个数

文档评论(0)

132****9295 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档