- 1、本文档共58页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 山东职业学院档案管理.pdf VIP
- 冀教版小学数学四年级下册【全册】课时练+单元测试卷(含答案).pdf VIP
- DB11T 214-2016 居住区绿地设计规范.pdf VIP
- 国家开放大学电大本科《C语言程序设计》期末试题标准题库及答案(试卷号:1253).pdf VIP
- 天津专用2025届高考化学一轮复习考点规范练37生命中的基础有机化合物有机合成含解析.docx VIP
- 爆破工程技术人员取证培训初级D设计题真题参考答案.pdf VIP
- 利安隆(珠海)新材料有限公司年产5.15万吨高分子材料抗老化助剂混配、造粒项目环评报告表.pdf VIP
- 医生三基三严知识题库(附答案).docx VIP
- 2025年【N1叉车司机】考试及N1叉车司机考试题库(含答案).docx
- 未成年人防性侵安全教育.pptx VIP
文档评论(0)