单片机原理、接口及应用 习题程序集

单片机原理、接口及应用 习题程序集

ID:18666724

大小:56.50 KB

页数:10页

时间:2018-09-20

单片机原理、接口及应用 习题程序集_第1页
单片机原理、接口及应用 习题程序集_第2页
单片机原理、接口及应用 习题程序集_第3页
单片机原理、接口及应用 习题程序集_第4页
单片机原理、接口及应用 习题程序集_第5页
资源描述:

《单片机原理、接口及应用 习题程序集》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、11ANLA,#0FHSWAPAANLP1,#0FHORLP1,ASJMP$12MOVA,R0XCHA,R1MOVR0,ASJMP$13.(1)利用乘法指令MOVB,#04HMULABSJMP$(2)利用位移指令RLARLAMOV20H,AANLA,#03HMOVB,AMOVA,20HANLA,#0FCHSJMP$(3)利用加法指令ADDA,ACCMOVR0,AMOVA,#0ADDCA,#0MOVB,AMOVA,R0ADDA,ACCMOVR1,AMOVA,BADDCA,BMOVB,AMOVA,R1SJMP$14XR

2、L40H,#3CHSJMP$15MOVA,20HADDA,21HDAAMOV22H,AMOVA,#0ADDCA,#0MOV23H,ASJMP$16MOVA,R0JZZEMOVR1,#0FFHSJMP$ZE:MOVR1,#0SJMP$17MOVA,50HMOVB,51HMULABMOV53H,BMOV52H,ASJMP$18MOVR7,#0AHWOP:XRLP1,#03HDJNZR7,WOPSJMP$19.单片机的移位指令只对A,且只有循环移位指令,为了使本单元的最高位移进下一单元的最低位,必须用大循环移位指令移位4

3、次。ORG0CLRCMOVA,20HRLCAMOV20H,AMOVA,21HRLCAMOV21H,AMOVA,22HRLCAMOV22H,AMOVA,#0RLCAMOV23H,ASJMP$1.因为是多个单元操作,为方便修改地址使用间址操作。片外地址用DPTR指示,只能用MOVX指令取数到A,片内地址用R0或R1指示,只能用MOV指令操作,因此循环操作外部数据存储器→A→内部数据存储器。ORG0000HMOVDPTR,#1000HMOVR0,#20HLOOP:MOVXA,@DPTRMOV@R0,AINCDPTRINC

4、R0CJNER0,#71H,LOOPSJMP$2.要注意两高字节相加应加低字节相加时产生的进位,同时要考虑最高位的进位。ORG0MOVA,R0ADDA,R6MOV50H,AMOVA,R7ADDCA,R1MOV51H,AMOVA,#0ADDCA,ACCMOV52H,ASJMP$3.A中放小于14H(20)的数,平方表的一个数据占两个字节,可用BCD码或二进制数存放。(如A中放的是BCD码,则要先转换成二进制数再查表。)ORG0MOVDPTR,#TABADDA,ACCPUSHACCMOVCA,@A+DPTRMOVR7,

5、APOPACCINCAMOVR6,ASJMP$TAB:DB00,00,00,01,00,04,00,09,00,16H,…DB…04H,001.先用异或指令判两数是否同号,在同号中判大小,异号中正数为大。ORG0MOVA,20HXRLA,21HANLA,#80HJZCMPJB20H.7,BGAG:MOV22H,20HSJMP$BG:MOV22H,21HSJMP$CMP:MOVA,20HCJNEA,21H,GRGR:JNCAGMOV22H,21HSJMP$6.将待转换的数分离出高半字节并移到低4位加30H;再将待转换

6、的数分离出低半字节加30H,安排好源地址和转换后数的地址指针,置好循环次数。ORG0000HMOVR7,#05HMOVR0,#20HMOVR1,#25HNET:MOVA,@R0ANLA,#0F0HSWAPAADDA,#30HMOV@R1,AINCR0INCR1DJNZR7,NESJMP$END7.片内RAM间址寄存器只能有R0和R1两个,而正数、负数和零共需3个寄存器指示地址,这时可用堆栈指针指示第三个地址,POP和PUSH在指令可自动修改地址。R0指正数存放地址和R1指负数存放地址,SP指源数据存放的末地址,PO

7、P指令取源数据,每取一个数地址减1。ORG0000HMOVR7,#10HMOVA,#0MOVR4,AMOVR5,AMOVR6,AMOVR0,#40HMOVR1,#50HMOVSP,#3FHNEXT:POPACCJZZER0JBACC.7,NEINCR4MOV@R0,AINCR0AJMPDJNE:INCR5MOV@R1,AINCR1AJMPDJZER0:INCR6DJ:DJNZR7,NEXTSJMP$END9.取补不同于求补码,求补码应对正、负数分别处理,而取补不分正、负数,因正、负数均有相对于模的补数。可用取反加1

8、求补,也可用模(00H)减该数的方法求补。ORG0000HMOVR7,#03HMOVR0,#DATAAB:INCR0MOVA,@R0MOVA,@R0CPLAADDA,#01MOV@RO,ACPLAADDCA,#0DJNZR7,ABSJMP$10.16个单字节累加应用ADD指令而不能用ADDC指令。和的低位存A,当和超过一个字节,和的高字节存于B,并要加进低位

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。