您好,欢迎访问三七文档
当前位置:首页 > 办公文档 > 模板/表格 > 51-单片机-汇编例题解析
17:33:23汇编语言程序设计例题例1两个无符号双字节数相加。设被加数存放于内部RAM的40H(高位字节),41H(低位字节),加数存放于50H(高位字节),51H(低位字节),和数存入40H和41H单元中。17:33:23START:CLRC;将Cy清零MOVR0,#41H;将被加数地址送数据指针R0MOVR1,#51H;将加数地址送数据指针R1AD1:MOVA,@R0;被加数低字节的内容送入AADDA,@R1;两个低字节相加MOV@R0,A;低字节的和存入被加数低字节中DECR0;指向被加数高位字节DECR1;指向加数高位字节MOVA,@R0;被加数高位字节送入AADDCA,@R1;两个高位字节带Cy相加MOV@R0,A;高位字节的和送被加数高位字节RET例1两个无符号双字节数相加。设被加数存放于内部RAM的40H(高位字节),41H(低位字节),加数存放于50H(高位字节),51H(低位字节),和数存入40H和41H单元中。17:33:23例2将两个半字节数合并成一个一字节数。设内部RAM40H#,41H单元中分别存放着8位二进制数,要求取出两个单元中的低半字节,并成一个字节后,存入50H单元中。17:33:23设内部RAM40H#,41H单元中分别存放着8位二进制数,要求取出两个单元中的低半字节,并成一个字节后,存入50H单元中START:MOVR1,#40H;设置R1为数据指针MOVA,@R1;取出第一个单元中的内容ANLA,#0FH;取第一个数的低半字节SWAPA;移至高半字节INCR1;修改数据指针XCHA,@R1;取第二个单元中的内容ANLA,#0FH;取第二个数的低半字节ORLA,@R1;拼字MOV50H,A;存放结果RET17:33:23例3x,y均为8位二进制数,设x存入R0,y存入R1,求解:y=syn(x)17:33:23例3x,y均为8位二进制数,设x存入R0,y存入R1,求解:y=syn(x)程序如下:START:CJNER0,#00H,SUL1;R0中的数与00比较不等转移MOVR1,#00H;相等,R1←0SJMPSUL2SUL1:JCNEG;两数不等,若(R0)0,转向NEGMOVR1,#01H;(R0)0,则R1←01HSJMPSUL2NEG:MOVR1,#0FFH;(R0)0,则R1←0FFHSUL2:RET17:33:23正确程序如下:SUBF:MOVA,R0JZZEROJBACC.7,NEGMOVR1,#1ZERO:MOVR1,#0SJMPENDFNEG:MOVR1,#0FFHENDF:RET17:33:2317:33:23例4比较两个无符号数的大小。设外部RAM的存储单元ST1和ST2中存放两个不带符号的二进制数,找出其中的大数存入外部RAM中的ST3单元中。17:33:23例4比较两个无符号数的大小。17:33:23程序如下:ORG1000HST1EQU2000HST2EQU2100HST3EQU2200HSTART:CLRC;清零CyMOVDPTR,#ST1;第一个数的指针MOVXA,@DPTR;取第一个数MOVR2,A;保存MOVDPTR,#ST2;第二个数的指针MOVXA,@DPTR;取第二个数CLRC17:33:23SUBBA,R2;JNCBIG2;若第二个数大,XCHA,R2;BIG1:MOVDPTR,#ST3MOVX@DPTR,A;RETBIG2:MOVXA,@DPTR;SJMPBIG1RET17:33:23例5工作单元清零。在应用系统程序设计时,有时经常需要将存储器中各部分地址单元作为工作单元,存放程序执行的中间值或执行结果,工作单元清零工作常常放在程序的初始化部分中。设有50个工作单元,其首址为外部存储器8000H单元,则其工作单元清零程序如下:17:33:23CLEAR:CLRAMOVDPTR,#8000H;工作单元首址送指针MOVR2,50;置循环次数CLEAR1:MOVX@DPTR,AINCDPTR;修改指针DJNZR2,CLEAR1;控制循环RET17:33:23例6设在内部RAM的BLOCK单元开始处有长度为LEN个的无符号数据块,试编一个求和程序,并将和存入内部RAM的SUM单元(设和不超过8位)。BLOCKEQU20HLENEQU30HSUMEQU40HSTART:CLRA;清累加器AMOVR2,#LEN;数据块长度送R2MOVR1,#BLOCK;数据块首址送R1LOOP:ADDA,@R1;循环加法INCR1;修改地址指针DJNZR2,LOOP;修改计数器并判断MOVSUM,A;存和RET17:33:23二、多重循环例710秒延时程序。延时程序与MCS-51执行指令的时间有关,如果使用6MHz晶振,一个机器周期为2μs,计算出一条指令以至一个循环所需要的执行时间,给出相应的循环次数,便能达到延时的目的。编写10秒延时程序17:33:23延时程序与MCS-51执行指令的时间有关,如果使用6MHz晶振,一个机器周期为2μs,计算出一条指令以至一个循环所需要的执行时间,给出相应的循环次数,便能达到延时的目的。10秒延时程序如下:DELAY:MOVR5,#100DEL0:MOVR6,#200DEL1:MOVR7,#248DEL2:DJNZR7,DEL2DJNZR6,DEL1DJNZR5,DEL0RET17:33:23上例程序中采用了多重循环程序,即在一个循环体中又包含了其它的循环程序,这种方式是实现延时程序的常用方法。使用多重循环时,必须注意:(1)循环嵌套,必须层次分明,不允许产生内外层循环交叉。(2)外循环可以一层层向内循环进入,结束时由里往外一层层退出。(3)内循环可以直接转入外循环,实现一个循环由多个条件控制的循环结构方式。17:33:23例8在内部RAM中从50H单元开始的连续单元依次存放了一串字符,该字符串以回车符为结束标志,测试该字符串长度。程序如下:START:MOVR2,#0FFHMOVR0,#4FH;数据指针R0置初值LOOP:INCR0INCR2CJNE@R0,#0DH,LOOPRET17:33:236查表程序设计查表程序是一种常用程序,它广泛使用于LED显示控制、打印机打印控制、数据补偿、数值计算、转换等功能程序中,这类程序具有简单、执行速度快等特点。所谓查表法,就是预先将满足一定精度要求的表示变量与函数值之间关系的一张表求出,然后把这张表存于单片机的程序存储器中,这时自变量值为单元地址,相应的函数值为该地址单元中的内容。查表,就是根据变量X在表格中查找对应的函数值Y,使Y=f(X)。17:33:23MCS-51指令系统中,有两条查表指令:MOVCA,@A+PCMOVCA,@A+DPTR17:33:23例9一个十六进制数存放在内部RAM的HEX单元的低4位中,将其转换成ASCII码并送回HEX单元。十六进制0~9的ASCII码为30H~39H,A~F的ASCII码为41H~46H,ASCII码表格的首地址为ASCTAB。编程如下:ORG1000HHEXASC:MOVA,HEXANLA,#0FHADDA,#3;修改指针MOVCA,@A+PCMOVHEX,ARET17:33:23ASCTAB:DB30H,31H,32H,33H,34HDB35H,36H,37H,38H,39HDB41H,42H,43H,44H,45HDB46H在这个程序中,查表指令MOVCA,@A+PC到表格首地址有两条指令,占用3个字节地址空间,故修改指针应加3。17:33:23例10设有一个巡回检测报警装置,需对96路输入进行控制,每路有一个额定的最大值,是双字节数。当检测量大于该路对应的最大值时,就越限报警。假设R2为保存检测路数的寄存器,其对应的最大额定值存放于31H和32H单元中。查找最大额定值的程序如下:FMAX:MOVA,R2ADDA,R2;表中一个额定值为2个字节MOV31H,AMOVDPTR,#TAB;表首址17:33:23MOVCA,@A+DPTR;XCHA,31H;第一个字节内容存入31HINCDPTRMOVCA,@A+DPTR;MOV32H,A;第二字节的内容存入32HTAB:DW1230H,1450H,...DW2230H,2440H,...DW3120H,3300H,...17:33:23例15在一个温度检测系统中,温度模拟信号由10位A/D输入。将A/D结果转换为对应温度值,可采用查表方法实现。先由实验测试出整个温度量程范围内的A/D转换结果,把A/D转换结果000H~3FFH所对应的温度值组织为一个表存储在程序存储器中,那么就可以根据检测到的模拟量的A/D转换值查找出相应的温度值。设测得的A/D转换结果已存入20H#,21H单元中(高位字节在20H中,低位字节在21H中),查表得到的温度值存放在22H#,23H单元(高位字节在22H中,低位字节在23H中)。17:33:23程序如下:FTMP:MOVDPTR,#TAB;DPTR←MOVA,21H;(20H)(21H)×2CLRCRLCAMOV21H,AMOVA,20HRLCAMOV20H,AMOVA,21H;表首地址+偏移量ADDCA,DPLMOVDPL,A17:33:23MOVA,20HADDCA,DPHMOVDPH,ACLRAMOVCA,@A+DPTR;MOV22H,ACLRAINCDPTRMOVCA,@A+DPTR;MOV23H,ARETTAB:DW…17:33:237数制转换例16将一个字节二进制数转换成3位非压缩型BCD码。设一个字节二进制数在内部RAM40H单元,转换结果放入内部RAM50H#,51H,52H单元中(高位在前),程序如下:HEXBCD:MOVA,40HMOVB,#100DIVABMOV50H,AMOVA,#10XCHA,BDIVABMOV51H,AMOV52H,BRET17:33:23例17设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+D017:33:23BCDHEX:MOVR0,#40H;R0指向最高位地址MOVR1,#03;计数值送R1MOVR2,#0;存放结果的高位清零MOVA,@R0MOVR3,ALOOP:MOVA,R3MOVB,#10MULABMOVR3,A;(R3)×10的低8位送R3MOVA,BXCHA,R2;(R3)×10的高8位暂存R2MOVB,#1017:33:23MULABADDA,R2MOVR2,A;R2×10+(R3×10)高8位送R2INCR0;取下一个BCD数MOVA,R3ADDA,@R0MOVR3,AMOVA,R2ADDCA,#0;加低字节来的进位MOVR2,ADJNZR1,LOOPRET17:33:238运算程序一、加、减法程序例18将40H开始存放的10个字节的数与50H开始存放的10个字节的数相减(假设被减数大于减数)。设被减数指针为R0,减数指针为R1,差数放回被减数单元,R5存放字节个数,则程序如下:17:33:23SUB:MOVR0,#40HMOVR1,#50HMOVR5,#10CLRCSUB1:MOVA,@R0SUBBA,@R1MOV@R0,AINCR0INCR1DJNZR5,SUB1RET17:33:23二、乘法运算程序在计算机中,常将乘法采用移位和加法来实现。例19将(R2R3)和(R6R7)中双字节无符号数相乘,结果存入R4R5R6R7。此乘法可以采用部分积右移的方法来实现,其程序框图如图4.6所示,程序如下:NMUL:MOVR4,#0;初始化MOVR5,#0CLRCMOVR0,#1617:33:23NMUL1:MOVA,R4;CyR4R5R6R7右移一位RRCAMOVR4,AMOVA,R5RRCAMOV
本文标题:51-单片机-汇编例题解析
链接地址:https://www.777doc.com/doc-4712660 .html