第3章指令与编程2.docVIP

  1. 1、本文档共58页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第3章指令与编程2

第九节 汇编语言典型编程方法 汇编语言编程只讲一些最基本的,复杂的运算不讲,因为后面还要讲单片机C语言编程,用单片机C语言编程有很大的优越性。学习了单片机C语言编程后,提倡用C语言和汇编语言混合编程,以C语言为主。 一、算术逻辑处理 例1: 将40H开始存放的 10 个字节的数与50H开始存放的10 个字节的数相减(假设被减数大于减数)。设被减数地址(指针)存放在 R0, 减数地址(指针)存放在R1, 差数放回被减数单元, R5 存放字节个数, 则程序如下: SUB: MOV R0, #40H ;被减数首地址 MOV R1, #50H;减数地址 MOV R5, #10 ;字节个数 CLR C ;清进位位 SUB1: MOV A, @R0 ;被减数送累加器A SUBB A, @R1;两数相减结果送A MOV @R0, A;结果送被减数地址 INC R0 ;指向下一个被减数 INC R1 ;指向下一个减数 DJNZ R5, SUB1 ;10个数未运算完,转SUB1 RET 例 2: 将两个半字节数合并成一个字节数。设内部RAM 40H, 41H单元中分别存放着 8 位二进制数, 要求取出两个单元中的低半字节, 并成一个字节,将40H的低字节为合成字节的高字节, 存入50H单元中。 程序如下: START: MOV R1, #40H ; 设置R1为数据指针 MOV A, @R1 ; 取40H中的内容 ANL A, #0FH ; 取40H的低半字节 SWAP A ; 40H低半字节移至高半字节 INC R1 ; 修改数据指针,指向41H; XCH A, @R1 ; 41H内容送A,40H低半字节送41H原40H低半字节送41H高半字节; ANL A, # 0FH ; 取41H的低半字节 ORL A, @R1 ; 拼字 MOV 50H, A ; 存放结果在50H RET 二、数制转换程序 例3: 将一个字节二进制数转换成 BCD码。 转换后存到RAM的20H、21H。 源程序: MOV B,#100 ; MOV A,#99H ;被转换数(153) DIV AB ;求百位,商在A,余数在B MOV 21H,A ;将百位数送RAM的21H MOV A,#10 ; XCH A,B ;被除数送A,除数送B DIV AB ;十位在A,个位在B SWAP A ;将十位移到高4位 ADD A,B ;将十位与个位合并,放到A MOV 20H,A ;将十位、个位存20H单元 RET (调二-BCD转换) 例4:二进制转换为十进制 将计数器的TH0读入R2,TL0读入R3,将读入的16位二进制转换为5位十进制(最大65535)。 1)转换结果为5位,必须占3个存储单元,将转换结果存到R4、R5、R6中。 2)二-十进制转换公式 i=0,…,M M为二进制的位数,从右向左,从0开始;ai为该位的值“1”或“0”。 如1010转换为二进制: 3)转换编程思路 如何编程实现转换,以上面1010中的最高位1为例: 20=1; 21=20+20=1×2=2;(1+1) 22=21+21=2×2=4;(2+2) 23=22+22=4×2=8;(4+4) 规律:当前位置的权值(如权值为3)是将从1开始每步自相加的结果。将所有系数为1的权值累加起来就是十进制的结果。 实现方法:把R2、R3中的二进制带进位位左移,就是最高位开始累加,每移一次,将R4、R5、R6带进位位自加(相当于乘2),最高位等于a15×215,如果最高位为1,循环16次就累加了16次,变成32768。依次类推,实现了转换。 4)参考源程序 Z0Y0:CLR A ;A清0; MOV R4,A ;R4、R5、R6清0,R4放最高位 MOV R5,A ; MOV R6,A ; MOV R7,#10H ;循环16次 LO30:CLR C ;进位位清0,进位位中存放的系数,最高为开始 MOV A,R3 ;以下将二进制带进位位左移(6句) RLC A ;低位的最高位送入C MOV R3,A ; MOV A,R2 ; RL

文档评论(0)

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

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

1亿VIP精品文档

相关文档