单片机汇编例题解析ppt课件.ppt

上传人:牧羊曲112 文档编号:1405535 上传时间:2022-11-20 格式:PPT 页数:54 大小:349KB
返回 下载 相关 举报
单片机汇编例题解析ppt课件.ppt_第1页
第1页 / 共54页
单片机汇编例题解析ppt课件.ppt_第2页
第2页 / 共54页
单片机汇编例题解析ppt课件.ppt_第3页
第3页 / 共54页
单片机汇编例题解析ppt课件.ppt_第4页
第4页 / 共54页
单片机汇编例题解析ppt课件.ppt_第5页
第5页 / 共54页
点击查看更多>>
资源描述

《单片机汇编例题解析ppt课件.ppt》由会员分享,可在线阅读,更多相关《单片机汇编例题解析ppt课件.ppt(54页珍藏版)》请在三一办公上搜索。

1、02:56:29,汇编语言程序设计例题,例 1 两个无符号双字节数相加。 设被加数存放于内部RAM的40H(高位字节), 41H(低位字节), 加数存放于50H(高位字节), 51H(低位字节), 和数存入 40H和41H单元中。,02:56:29,START: CLR C ; 将Cy清零 MOV R0, 41H ; 将被加数地址送数据指针R0 MOV R1, 51H ; 将加数地址送数据指针R1 AD1: MOV A, R0 ; 被加数低字节的内容送入AADD A,R1 ; 两个低字节相加MOV R0, A ; 低字节的和存入被加数低字节中 DEC R0 ; 指向被加数高位字节 DEC R1

2、 ; 指向加数高位字节 MOV A, R0 ; 被加数高位字节送入AADDC A, R1 ; 两个高位字节带Cy相加 MOV R0, A ; 高位字节的和送被加数高位字节 RET,例 1 两个无符号双字节数相加。 设被加数存放于内部RAM的40H(高位字节), 41H(低位字节), 加数存放于50H(高位字节), 51H(低位字节), 和数存入 40H和41H单元中。,02:56:29,例 2 将两个半字节数合并成一个一字节数。 设内部RAM 40H#, 41H单元中分别存放着 8 位二进制数, 要求取出两个单元中的低半字节, 并成一个字节后, 存入 50H单元中。,02:56:29,设内部R

3、AM 40H#, 41H单元中分别存放着 8 位二进制数, 要求取出两个单元中的低半字节, 并成一个字节后, 存入 50H单元中,START: MOV R1, 40H ; 设置R1为数据指针 MOV A, R1 ; 取出第一个单元中的内容 ANL A, 0FH ; 取第一个数的低半字节 SWAP A ; 移至高半字节 INC R1 ; 修改数据指针 XCH A, R1 ; 取第二个单元中的内容 ANL A, 0FH ; 取第二个数的低半字节 ORL A, R1 ; 拼字 MOV 50H, A ; 存放结果RET,02:56:29,例 3 x, y均为8位二进制数, 设 x存入R0, y存入R1

4、, 求解: y=syn(x),02:56:29,例 3 x, y均为8位二进制数, 设 x存入R0, y存入R1, 求解: y=syn(x),程序如下: START: CJNE R0, 00H, SUL1 ; R0中的数与00比较不等转移 MOV R1, 00H; 相等, R1 0 SJMP SUL2 SUL1: JC NEG ; 两数不等, 若(R0)0, 则 R101H SJMP SUL2 NEG : MOV R1, 0FFH ; (R0)0, 则 R10FFH SUL2 : RET,02:56:29,正确程序如下: SUBF : MOV A,R0 JZ ZERO JB ACC.7 , N

5、EG MOV R1, #1 ZERO : MOV R1 , #0 SJMP ENDF NEG : MOV R1 , #0FFH ENDF : RET,02:56:29,02:56:29,例 4 比较两个无符号数的大小。 设外部 RAM 的存储单元 ST1和 ST2中存放两个不带符号的二进制数, 找出其中的大数存入外部 RAM 中的 ST3单元中。,02:56:29,例 4 比较两个无符号数的大小。,02:56:29,程序如下: ORG 1000H ST1 EQU 2000H ST2 EQU 2100H ST3 EQU 2200H START: CLR C ; 清零Cy MOV DPTR, ST

6、1 ; 第一个数的指针 MOVX A, DPTR ; 取第一个数 MOV R2, A ; 保存 MOV DPTR, ST2 ; 第二个数的指针 MOVX A, DPTR ; 取第二个数 CLR C,02:56:29,SUBB A, R2; 两数比较JNC BIG2 ; 若第二个数大, 则转XCH A, R2; 第一个数大BIG1: MOV DPTR, ST3 MOVX DPTR, A ; 存大数RETBIG2: MOVX A, DPTR; 第二个数大SJMP BIG1RET,02:56:29,例 5 工作单元清零。 在应用系统程序设计时, 有时经常需要将存储器中各部分地址单元作为工作单元, 存

7、放程序执行的中间值或执行结果, 工作单元清零工作常常放在程序的初始化部分中。 设有50个工作单元, 其首址为外部存储器8000H单元, 则其工作单元清零程序如下:,02:56:29,CLEAR: CLR A MOV DPTR, 8000H ; 工作单元首址送指针 MOV R2, 50 ; 置循环次数 CLEAR1: MOVX DPTR, A INC DPTR ; 修改指针 DJNZ R2, CLEAR1; 控制循环 RET,02:56:29,例 6 设在内部 RAM的BLOCK单元开始处有长度为LEN个的无符号数据块, 试编一个求和程序, 并将和存入内部 RAM的SUM单元(设和不超过 8 位

8、)。,BLOCK EQU 20H LEN EQU 30H SUM EQU 40HSTART: CLR A ; 清累加器A MOV R2, LEN; 数据块长度送R2 MOV R1, BLOCK ; 数据块首址送R1 LOOP: ADD A, R1 ; 循环加法 INC R1; 修改地址指针 DJNZ R2, LOOP ; 修改计数器并判断 MOV SUM, A; 存和 RET,02:56:29,二、 多重循环,例 7 10 秒延时程序。 延时程序与 MCS - 51 执行指令的时间有关, 如果使用 6 MHz晶振, 一个机器周期为 2 s, 计算出一条指令以至一个循环所需要的执行时间, 给出相

9、应的循环次数, 便能达到延时的目的。编写10 秒延时程序,02:56:29,延时程序与 MCS - 51 执行指令的时间有关,如果使用 6 MHz晶振, 一个机器周期为2 s, 计算出一条指令以至一个循环所需要的执行时间, 给出相应的循环次数, 便能达到延时的目的。10 秒延时程序如下: DELAY: MOV R5, 100 DEL0: MOV R6, 200 DEL1: MOV R7, 248 DEL2: DJNZ R7, DEL2 DJNZ R6, DEL1 DJNZ R5, DEL0 RET,02:56:29,上例程序中采用了多重循环程序, 即在一个循环体中又包含了其它的循环程序, 这种

10、方式是实现延时程序的常用方法。 使用多重循环时, 必须注意: (1) 循环嵌套, 必须层次分明, 不允许产生内外层循环交叉。 (2) 外循环可以一层层向内循环进入, 结束时由里往外一层层退出。 (3) 内循环可以直接转入外循环, 实现一个循环由多个条件控制的循环结构方式。,02:56:29,例8 在内部 RAM中从50H单元开始的连续单元依次存放了一串字符,该字符串以回车符为结束标志,测试该字符串长度。,程序如下: START: MOV R2, 0FFH MOV R0, 4FH ; 数据指针R0置初值 LOOP: INC R0 INC R2 CJNE R0, 0DH, LOOP RET,02:

11、56:29,6 查表程序设计,查表程序是一种常用程序, 它广泛使用于 LED显示控制、 打印机打印控制、数据补偿、数值计算、转换等功能程序中, 这类程序具有简单、执行速度快等特点。 所谓查表法, 就是预先将满足一定精度要求的表示变量与函数值之间关系的一张表求出, 然后把这张表存于单片机的程序存储器中, 这时自变量值为单元地址, 相应的函数值为该地址单元中的内容。查表, 就是根据变量 X在表格中查找对应的函数值 Y, 使 Y=f(X)。,02:56:29,MCS - 51指令系统中, 有两条查表指令: MOVC A, A+PC MOVC A, A+DPTR,02:56:29,例 9 一个十六进制

12、数存放在内部 RAM 的 HEX单元的低 4 位中, 将其转换成ASCII码并送回 HEX单元。 十六进制 09的ASCII码为 30H39H, AF的ASCII码为41H46H, ASCII码表格的首地址为ASCTAB。编程如下:,ORG 1000H HEXASC: MOV A, HEX ANL A, 0FH ADD A, 3; 修改指针 MOVC A, A+PC MOV HEX, A RET,02:56:29,ASCTAB: DB 30H, 31H, 32H, 33H, 34H DB 35H, 36H, 37H, 38H, 39H DB 41H, 42H, 43H, 44H, 45H DB

13、 46H 在这个程序中, 查表指令MOVC A, A+PC到表格首地址有两条指令, 占用 3 个字节地址空间, 故修改指针应加 3。,02:56:29,例 10 设有一个巡回检测报警装置, 需对 96 路输入进行控制, 每路有一个额定的最大值, 是双字节数。当检测量大于该路对应的最大值时, 就越限报警。假设R2 为保存检测路数的寄存器, 其对应的最大额定值存放于 31H和 32H单元中。 查找最大额定值的程序如下:,FMAX: MOV A, R2 ADD A, R2 ; 表中一个额定值为2个字节 MOV 31H, A MOV DPTR, TAB ; 表首址,02:56:29,MOVC A, A

14、+DPTR; 查表读取第一个字节 XCH A, 31H ; 第一个字节内容存入31H INC DPTR MOVC A, A+DPTR; 查表读取第二个字节 MOV 32H, A ; 第二字节的内容存入32H TAB: DW 1230H, 1450H, . DW 2230H, 2440H, . DW 3120H, 3300H, .,02:56:29,例 15 在一个温度检测系统中, 温度模拟信号由 10 位A/D输入。将A/D结果转换为对应温度值, 可采用查表方法实现。 先由实验测试出整个温度量程范围内的A/D转换结果, 把A/D转换结果000H3FFH所对应的温度值组织为一个表存储在程序存储器

15、中, 那么就可以根据检测到的模拟量的 A/D转换值查找出相应的温度值。 设测得的A/D转换结果已存入 20H#, 21H单元中(高位字节在20H中, 低位字节在21H中), 查表得到的温度值存放在22H#,23H单元(高位字节在 22H中, 低位字节在23H中)。,02:56:29,程序如下: FTMP: MOV DPTR, TAB ; DPTR表首地址 MOVA, 21H ; (20H)(21H)2CLRCRLCAMOV21H, AMOVA, 20HRLCAMOV20H, AMOVA, 21H ; 表首地址+偏移量 ADDC A, DPLMOVDPL, A,02:56:29,MOVA, 20

16、HADDC A, DPHMOVDPH, ACLR AMOVC A, A+DPTR; 查表得温度值高位字节MOV22H, ACLRAINCDPTRMOVC A, A+DPTR; 查表得温度值低位字节MOV23H, ARETTAB: DW ,02:56:29,7 数制转换,例 16 将一个字节二进制数转换成 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

17、DIV AB MOV 51H, A MOV 52H, B RET,02:56:29,例 17 设 4 位BCD码依次存放在内存 RAM中 40H43H单元的低4 位, 高 4 位都为 0, 要求将其转换为二进制数, 结果存入 R2R3 中。 一个十进制数可表示为: Dn10n +Dn-110n-1 + + D0100 =(Dn10+Dn-1)10+Dn-2)10+)+D0当n=3时, 上式可表示为: (D310+D2)10+D1)10+D0,02:56:29,BCDHEX: MOV R0, 40H ; R0指向最高位地址MOV R1, 03 ; 计数值送R1MOV R2, 0 ; 存放结果的高

18、位清零MOV A, R0MOV R3, A LOOP: MOV A, R3MOV B, 10MULABMOV R3, A ; (R3)10 的低 8 位送R3MOV A, BXCHA, R2 ; (R3)10的高 8 位暂存R2MOVB, 10,02:56:29,MULAB ADD A, R2 MOVR2, A ; R210+( R310)高 8 位送R2 INCR0 ; 取下一个 BCD数 MOVA, R3 ADDA, R0 MOVR3, A MOVA, R2 ADDC A, 0 ; 加低字节来的进位 MOVR2, A DJNZ R1, LOOP RET,02:56:29,8 运算程序,一、

19、 加、 减法程序,例 18 将40H开始存放的 10 个字节的数与 50H开始存放的10 个字节的数相减(假设被减数大于减数)。 设被减数指针为 R0, 减数指针为 R1, 差数放回被减数单元, R5 存放字节个数, 则程序如下:,02:56:29,SUB: MOV R0, 40HMOV R1, 50HMOV R5, 10CLR CSUB1: MOV A, R0SUBB A, R1MOV R0, AINC R0INC R1DJNZ R5, SUB1RET,02:56:29,二、 乘法运算程序 在计算机中, 常将乘法采用移位和加法来实现。 例19 将(R2R3)和(R6R7)中双字节无符号数相乘

20、, 结果存入 R4R5R6R7。 此乘法可以采用部分积右移的方法来实现, 其程序框图如图 4.6 所示, 程序如下:,NMUL: MOV R4, 0 ; 初始化 MOV R5, 0 CLR C MOV R0, 16,02:56:29,NMUL1: MOV A, R4 ; CyR4R5R6R7右移一位 RRC A MOV R4, A MOV A, R5 RRC A MOV R5, A MOV A, R6 RRC A MOV R6, A MOV A, R7 RRC MOV R7, A JNC NMUL2; C为移出乘数的最低位 MOV A, R5 ; (R4R5)+(R6F7)(R4R5),02:

21、56:29,ADD A, R3 MOV R5, A MOV A, R4 ADDC A, R2 MOV R4, A NMUL2: DJNZR0, NMUL1; 循环16位 MOV A, R4; 最后结果再移一位 RRC A MOV R4, A MOV A, R5 RRC A MOV R5, A MOV A, R6 RRC A MOV R6, A MOV A, R7 RRC A MOV R7, A RET,02:56:29,图7.6 NMUL程序框图,02:56:29,例 假定被乘数在(R4R3)中, 乘数放在R2中, 乘积放在R7R6和R5中。 MCS - 51 中有 8 位数的乘法指令MUL,

22、 用它来实现多字节乘法时, 可表示为 (R4R3)(R2) =(R4)28+(R3)(R2)=(R4)(R2)28+(R3)(R2)其中(R4)(R2)和(R3)(R2)都是可直接用MUL指令来实现, 而乘以28意味着左移 8 位。由此可编写如下程序:,02:56:29,NMUL1: MOV A, R2 MOV B, R3 MUL AB ; (R3)(R2) MOV R5, A ; 积的低位送R5 MOV R6, B ; 积的高位送R6 MOV A, R2 MOV B, R4 MUL AB ; (R4)(R2) ADD A, R6 ; (R3)(R2)的高位加(R4)(R2)的低位MOV A,

23、 B ADDC A, 00H ; (R4)(R2)的高位加Cy MOV R7, A ; 结果送R7 RET,02:56:29,三、 除法运算程序 除法是乘法的逆运算, 用移位、 相减的方法来完成。 首先比较被除数的高位字与除数, 如被除数高位大于除数, 则商为1, 并从被除数中减去除数, 形成一个部分余数; 否则商位为 0, 不执行减法。 然后把新的部分余数左移一位, 并与除数再次进行比较。循环此步骤, 直到被除数的所有位都处理完为止,一般商的字长为 n, 则需循环n次。 一般计算机中, 被除数均为双倍位, 即如果除数和商为双字节, 则被除数为四字节。如果在除法中发生商大于规定字节, 称为溢出

24、。 在进行除法前, 应该检查是否会产生溢出。一般可在进行除法前, 先比较被除数的高位与除数, 如被除数高位大于除数, 则溢出, 置溢出标志, 不执行除法。,02:56:29,图 7.7 除法程序的流程,02:56:29,例 21 将(R4R5R6R7)除以(R2R3), 商放在(R6R7)中, 余数放在(R4R5)中。,NDIV: MOV A, R5 ; 判商是否产生溢出 CLR C SUBB A, R3 MOV A, R4 SUBB A, R2 JNC NDIV1 ; 溢出, 转溢出处理 MOV B, 16; 无溢出, 执行除法,02:56:29,NDIV2: CLR C ; 被除数左移一位

25、, 低位送 0 MOV A, R7 RLC A MOV R7, A MOV A, R6 RLC A MOV R6, A MOV A, R5 RLC A MOV R5, A XCH A, R4 RLC A XCH A, R4,02:56:29,MOV F0, C ; 保护移出的最高位 CLR C SUBB A, R3 ; 部分余数与除数比较 MOV R1, A MOV A, R4 SUBB A, R2 JB F0, NDIV3; 移出的高位为 1, 肯定够减 JC NDIV4 ; 否则, (Cy) = 0才够减 NDIV3: MOV R4, A ; 回送减法结果 MOV A, R1 MOV R5

26、, A INC R7 ; 商上1,02:56:29,NDIV4: DJNZ B, NDIV2; 循环次数减 1 ,若不为零则循环 CLR F0 ; 正常执行无溢出 F0 = 0 RET NDIV1: SETB F0 ; 溢出F0=1 RET,02:56:29,将20H当中的8位无符号数转换成3位BCD码存放在30H和31H中,30H放百位,个位十位放31H,BCDCHG: MOV A,20H MOV B,#100 DIV AB MOV 30H,A MOV A,B MOV B,#10 DIV AB SWAP A ORL A,B MOV 31H,A RET,02:56:29,例 设有一带符号的数组

27、存放在内部RAM以20H为首址的连续单元中,其长度为90,要求找出其中的最大值,并将其存放到内部RAM的1FH单元中,试编写相应的程序。,02:56:29,程序如下,ORG1000HSTART:MOVR0, #20H;置取数指针R0初值 MOVB, #59H;置循环计数器B初值 MOVA, R0;第一个数送ALOOP: INC R0;修改指针 MOVR1, A;暂存 XRLA, R0;两数符号相同? JB ACC.7, LAT ;若相异,则转LAT MOV A, R1;若相同,则恢复A中原来值 CLR C;C清零 SUBB A, R0 ;两数相减,以判断两者的大小,02:56:29,JNB A

28、CC.7, SM1 ;若A中值为大,则转SM1CXA: MOV A, R0 ;若A中值为小,则将大数送入A SJMP SM2LAT: XRL A, R0 ;恢复A中原值MOV A, R1 JNB ACC.7, SM2 ;若A中值为正,侧转SM2 SJMP CXA ;若A中值为负,则转CXASM1: MOV A, R1 ;恢复A中原值SM2: DJNZ B, LOOPMOV 1FH, A ;最大者送1FH单元 END,02:56:29,例4-10 试编写程序,计算,分析:0、1、.、9存放在内部RAM的20H开始的存储区域内,计算所得结果存放在R3、R2中。要求:平方运算编写成子程序SORT,主

29、程序通过调用SORT并求和完成运算。参数的传递用累加器。,4.2.5 子程序,-子程序应用,02:56:29,SJMPENSORT: MOVDPTR, #TAB ;进入子程序查平方表 MOVCA, A+DPTR RET ;返主程序TAB: DB0, 1, 4, 9, 16 DB25, 36, 49, 64, 81EN: NOP END,4.2.5 子程序,-子程序应用,02:56:29,ORG8000HMAIN: MOVR0, #20H;置数据指针MOVR7, #10 ;置计数初值MOVR3, #0;结果单元清零MOVR2, #0LOOP: MOVA, R0;取数ACALLSORT;调用求平方子程序ADDA, R2;累加平方和MOVR2, A MOV A,R3ADDC A, #0 ;加进位Cy MOV R3, AINCR0 ;修改指针DJNZR7, LOOP;未完,继续,4.2.5 子程序,-子程序应用,02:56:29,4.9 设自变量X为一无符号数,存放在内部RAM的VAX单元,函数Y存放在FUNC单元。请编写满足如下关系的程序:X=50时:Y=X;50X=20时:Y=5X;X20时:Y=2X;,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号