第三章3单片机-汇编语言程序设计例题.ppt_第1页
第三章3单片机-汇编语言程序设计例题.ppt_第2页
第三章3单片机-汇编语言程序设计例题.ppt_第3页
第三章3单片机-汇编语言程序设计例题.ppt_第4页
第三章3单片机-汇编语言程序设计例题.ppt_第5页
已阅读5页,还剩43页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

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

2、节 MOV A, R0 ; 被加数高位字节送入A ADDC A, R1 ; 两个高位字节带Cy相加 MOV R0, A ; 高位字节的和送被加数高位字节 RET,例 2 将两个半字节数合并成一个一字节数。 设内部RAM 40H#, 41H单元中分别存放着 8 位二进制数, 要求取出两个单元中的低半字节, 并成一个字节后, 存入 50H单元中。,例 2 将两个半字节数合并成一个一字节数。 ,START: MOV R1, 40H ; 设置R1为数据指针 MOV A, R1 ; 取出第一个单元中的内容 ANL A, 0FH ; 取第一个数的低半字节 SWAP A ; 移至高半字节 INC R1 ;

3、修改数据指针 XCH A, R1 ; 取第二个单元中的内容 ANL A, 0FH ; 取第二个数的低半字节 ORL A, R1 ; 拼字 MOV 50H, A ; 存放结果 RET,例 3 x, y均为8位二进制数, 设 x存入R0, y存入R1, 求解: y=syn(x),例 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, 则 R10

4、1H SJMP SUL2 NEG : MOV R1, 0FFH ; (R0)0, 则 R10FFH SUL2 : RET,正确程序如下: SUBF : MOV A,R0 JZ ZERO JB ACC.7 , NEG MOV R1, #1 ZERO : MOV R1 , #0 SJMP ENDF NEG : MOV R1 , #0FFH ENDF : RET,例 4 比较两个无符号数的大小。 设外部 RAM 的存储单元 ST1和 ST2中存放两个不带符号的二进制数, 找出其中的大数存入外部 RAM 中的 ST3单元中。,例 4 比较两个无符号数的大小。,程序如下: ORG 1000H ST1 E

5、QU 2000H ST2 EQU 2100H ST3 EQU 2200H START: CLR C ; 清零Cy MOV DPTR, ST1 ; 第一个数的指针 MOVX A, DPTR ; 取第一个数 MOV R2, A ; 保存 MOV DPTR, ST2 ; 第二个数的指针 MOVX A, DPTR ; 取第二个数 CLR C,SUBB A, R2; 两数比较 JNC BIG2 ; 若第二个数大, 则转 XCH A, R2; 第一个数大 BIG1: MOV DPTR, ST3 MOVX DPTR, A ; 存大数 RET BIG2: MOVX A, DPTR; 第二个数大 SJMP BI

6、G1 RET,例 5 工作单元清零。 在应用系统程序设计时, 有时经常需要将存储器中各部分地址单元作为工作单元, 存放程序执行的中间值或执行结果, 工作单元清零工作常常放在程序的初始化部分中。 设有50个工作单元, 其首址为外部存储器8000H单元, 则其工作单元清零程序如下:,CLEAR: CLR A MOV DPTR, 8000H ; 工作单元首址送指针 MOV R2, 50 ; 置循环次数 CLEAR1: MOVX DPTR, A INC DPTR ; 修改指针 DJNZ R2, CLEAR1; 控制循环 RET,例 6 设在内部 RAM的BLOCK单元开始处有长度为 LEN个的无符号数

7、据块, 试编一个求和程序, 并将和存入内部 RAM的 SUM单元(设和不超过 8 位)。,BLOCK EQU 20H LEN EQU 30H SUM EQU 40H START: CLR A ; 清累加器A MOV R2, LEN; 数据块长度送R2 MOV R1, BLOCK ; 数据块首址送R1 LOOP: ADD A, R1 ; 循环加法 INC R1; 修改地址指针 DJNZ R2, LOOP ; 修改计数器并判断 MOV SUM, A; 存和 RET,二、 多重循环,例 7 10 秒延时程序。 延时程序与 MCS - 51 执行指令的时间有关, 如果使用 6 MHz晶振, 一个机器周

8、期为 2 s, 计算出一条指令以至一个循环所需要的执行时间, 给出相应的循环次数, 便能达到延时的目的。编写10 秒延时程序,二、 多重循环,例 7 10 秒延时程序。 延时程序与 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

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

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

11、例 9 一个十六进制数存放在内部 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,ASCTAB: DB 30H, 31H, 32H, 33H, 34H DB 35H, 36H, 37H, 38H, 39H DB 41H, 42H, 43H, 44H, 45H D

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

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

14、找出相应的温度值。 设测得的A/D转换结果已存入 20H#, 21H单元中(高位字节在20H中, 低位字节在21H中), 查表得到的温度值存放在22H#,23H单元(高位字节在 22H中, 低位字节在23H中)。,程序如下: FTMP: MOV DPTR, TAB ; DPTR表首地址 MOVA, 21H ; (20H)(21H)2 CLRC RLCA MOV21H, A MOVA, 20H RLCA MOV20H, A MOVA, 21H ; 表首地址+偏移量 ADDC A, DPL MOVDPL, A,MOVA, 20H ADDC A, DPH MOVDPH, A CLR A MOVC A

15、, A+DPTR; 查表得温度值高位字节 MOV22H, A CLRA INCDPTR MOVC A, A+DPTR; 查表得温度值低位字节 MOV23H, A RET TAB: DW ,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 DIV AB MOV 51H, A MOV 52H, B RET,例

16、 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,BCDHEX: MOV R0, 40H ; R0指向最高位地址 MOV R1, 03 ; 计数值送R1 MOV R2, 0 ; 存放结果的高位清零 MOV A, R0 MOV R3, A LOOP: MOV A, R3 MOV B, 10

17、 MULAB MOV R3, A ; (R3)10 的低 8 位送R3 MOV A, B XCHA, R2 ; (R3)10的高 8 位暂存R2 MOVB, 10,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,8 运算程序,一、 加、 减法程序,例 18 将40H开始存放的 10 个字节的数与 50H开始存放的10 个字节的数相减(假设被减数大

18、于减数)。 设被减数指针为 R0, 减数指针为 R1, 差数放回被减数单元, R5 存放字节个数, 则程序如下:,SUB: MOV R0, 40H MOV R1, 50H MOV R5, 10 CLR C SUB1: MOV A, R0 SUBB A, R1 MOV R0, A INC R0 INC R1 DJNZ R5, SUB1 RET,二、 乘法运算程序 在计算机中, 常将乘法采用移位和加法来实现。 例19 将(R2R3)和(R6R7)中双字节无符号数相乘, 结果存入 R4R5R6R7。 此乘法可以采用部分积右移的方法来实现, 其程序框图如图 4.6 所示, 程序如下:,NMUL: MO

19、V R4, 0 ; 初始化 MOV R5, 0 CLR C MOV R0, 16,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),ADD A, R3 MOV R5, A MOV A, R4 ADDC A, R2 MOV R4, A NMUL2: DJNZR0, NMUL1; 循环16位

20、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,图7.6 NMUL程序框图,例 20 假定被乘数在(R4R3)中, 乘数放在R2中, 乘积放在R7R6和R5中。 MCS - 51 中有 8 位数的乘法指令MUL, 用它来实现多字节乘法时, 可表示为 (R4R3)(R2) =(R4)28+(R3)(R2) =(R4)(R2)28+(R3)(R2) 其中(R4)(R2)和(R3)(R2)都是可直接用MUL指令来实

21、现, 而乘以28意味着左移 8 位。由此可编写如下程序:,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, B ADDC A, 00H ; (R4)(R2)的高位加Cy MOV R7, A ; 结果送R7 RET,三、 除法运算程序 除法是乘法的逆运算, 用移位、 相减的方法来完成。 首先比较被除数的高位字与除数, 如被除数高位大于除数, 则商为1, 并从被除数中减去除数, 形成一个部分余数; 否则商位为 0, 不执行减法。 然后把新的部分余数左移一位, 并与除数再次进行比较。循环此步骤, 直到被除数的所有位都处理完为止,一般商的字长为 n, 则需循环n次。 一般计算机中, 被除数均为双倍位, 即如果

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论