_单片机-汇编语言程序设计例题 2

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

MOV R0, #4FH ; 数据指针R0置初值
LOOP: INC R0 INC R2 CJNE @R0, #0DH, LOOP RET
6 查表程序设计
查表程序是一种常用程序, 它广泛使用于 LED显示控制、 打印机打印控制、数据补偿、数值计算、转换等功能程序中,
这类程序具有简单、执行速度快等特点。
DB 46H
在这个程序中, 查表指令MOVC A, @A+PC到表格首 地址有两条指令, 占用 3 个字节地址空间, 故修改指针应加 3。
例 10 设有一个巡回检测报警装置, 需对 96 路输入进行 控制, 每路有一个额定的最大值, 是双字节数。当检测量大于 该路对应的最大值时, 就越限报警。假设R2 为保存检测路数
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, @A+DPTR; 查表得温度值高位字节 MOV22H, A CLRA INCDPTR
例 2 将两个半字节数合并成一个一字节数。
设内部RAM 40H, 41H单元中分别存放着 8 位二进制数,
要求取出两个单元中的低半字节 , 并成一个字节后 , 存入 50H单元中。
例 2 将两个半字节数合并成一个一字节数。 START: MOV R1, #40H ; 设置R1为数据指针 MOV A, @R1 ; 取出第一个单元中的内容 ANL A, #0FH ; 取第一个数的低半字节 SWAP A ; 移至高半字节 INC R1 ; 修改数据指针 XCH A, @R1 ; 取第二个单元中的内容 ANL A, # 0FH ; 取第二个数的低半字节
DELAY: MOV R5, #100
DEL0:
DEL1: DEL2:
MOV R6, #200
MOV R7, #248 DJNZ R7, DEL2 DJNZ R6, DEL1 DJNZ R5, DEL0
RET
上例程序中采用了多重循环程序 , 即在一个循环体中又包 含了其它的循环程序, 这种方式是实现延时程序的常用方法。 使用多重循环时, 必须注意: (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 ADD A,@R1 MOV @R0, A DEC R0 DEC R1 MOV A, @R0 ADDC A, @R1 MOV @R0, A RET ; 被加数低字节的内容送入A ; 两个低字节相加 ; 低字节的和存入被加数低字节中 ; 指向被加数高位字节 ; 指向加数高位字节 ; 被加数高位字节送入A ; 两个高位字节带Cy相加 ; 高位字节的和送被加数高位字节
例 4 比较两个无符号数的大小。
设外部 RAM 的存储单元 ST1和 ST2
中存放两个不带符号的二进制数 , 找出其中 的大数存入外部 RAM 中的 ST3单元中。
例 4 比较两个无符号数的大小。
程序如下: ORG ST1 ST2 ST3 EQU EQU EQU 1000H 2000H 2100H 2200H ; 清零Cy
START: CLR C
MOV DPTR, #ST1 ; 第一个数的指针
MOVX A, @DPTR
MOV R2, A MOVX A, @DPTR CLR C
; 取第一个数
; 保存 ; 取第二个数
MOV DPTR, #ST2 ; 第二个数的指针
SUBB A, R2; 两数比较 JNC BIG2 ; 若第二个数大, 则转 XCH A, R2; 第一个数大 BIG1: MOV DPTR, #ST3
MOVC A, @A+PC
MOVC A, @A+DPTR
例 9 一个十六进制数存放在内部 RAM 的 HEX单元的
低 4 位中, 将其转换成ASCII码并送回 HEX单元。
十六进制 下: 0~9的ASCII码为30H~39H, A~F的ASCII
码为41H~ 46H, ASCII码表格的首地址为 ASCTAB。编程如
MUL AB
ADD A, R2 MOV R2, A ; R2×10+( R3×10)高 8 位送R2
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
例 17 设 4 位BCD码依次存放在内存 RAM中 40H~43H 单元的低4 位, 高 4 位都为 0, 要求将其转换为二进制数, 结
MOV R1, #03 ; 计数值送R1 MOV R2, #0 ; 存放结果的高位清零
MOV A, @R0
MOV R3, A LOOP: MOV A, R3
MOV B, #10
MUL AB MOV R3, A ; (R3)×10 的低 8 位送R3 MOV A, B XCHA, R2 ; (R3)×10的高 8 位暂存R2 MOVB, #10
二、 多重循环
例 7 10 秒延时程序。
延时程序与 MCS - 51 执行指令的时间有关, 如果 使用 6 MHz晶振, 一个机器周期为 2 μs, 计算出一条 指令以至一个循环所需要的执行时间 , 给出相应的循 环次数, 便能达到延时的目的。编写10 秒延时程序
二、 多重循环 例 7 10 秒延时程序。 延时程序与 MCS - 51 执行指令的时间有关, 如果使用 6 MHz晶振, 一个机器周期为 2 μs, 计算出一条指令以至一个循 环所需要的执行时间, 给出相应的循环次数, 便能达到延时的 目的。10 秒延时程序如下:
SJMP SUL2
NEG : MOV R1, #0FFH ; (R0)<0, 则 R1←0FFH SUL2 : RET
程序如下:
SUBF : MOV A,R0 JZ ZERO JB ACC.7 , NEG MOV R1, #1
SJMP ENDF
ZERO : MOV R1 , #0 SJMP ENDF NEG : MOV R1 , #0FFH ENDF : RET
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, 转向NEG MOV R1, #01H ; (R0)>0, 则 R1←01H
的寄存器, 其对应的最大额定值存放于 31H和 32H单元中。
查找最大额定值的程序如下: FMAX: MOV A, R2 ADD A, R2 ; 表中一个额定值为2个字节 MOV 31H, A MOV DPTR, #TAB ; 表首址
MOVC A, @A+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, ...
果存入 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+D0
BCDHEX: MOV R0, #40H
; R0指向最高位地址
(2) 外循环可以一层层向内循环进入, 结束时由里往外一
层层退出。
(3) 内循环可以直接转入外循环, 实现一个循环由多个条
件控制的循环结构方式。
例8 在内部 RAM中从 50H单元开始的连续单元
依次存放了一串字符, 该字符串以回车符为结束标志, 要求测试该字符串的长度。
程序如下: START: MOV R2, #0FFH
其工作单元清零程序如下:
CLEAR: CLR A MOV DPTR, #8000H ; 工作单元首址送指针 MOV R2, #50 ; 置循环次数 CLEAR1: MOVX @DPTR, A INC DPTR ; 修改指针
DJNZ R2, CLEAR1; 控制循环
RET
例 6
设在内部 RAM的BLOCK单元开始处有长度为
LEN个的无符号数据块, 试编一个求和程序, 并将和存入内
部 RAM的 SUM单元(设和不超过 8 位)。 BLOCK EQU 20H LEN EQU 10H 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
所谓查表法, 就是预先将满足一定精度要求的表示变量与 函数值之间关系的一张表求出, 然后把这张表存于单片机的程 序存储器中, 这时自变量值为单元地址, 相应的函数值为该地 址单元中的内容。查表, 就是根据变量 X在表格中查找对应的 函数值 Y, 使 Y=f(X)。
MCS - 51指令系统中, 有两条查表指令:
MOVC A, @A+DPTR; 查表得温度值低位字节
MOV23H, A RET
TAB: DW …
7 数制转换
例 16 将一个字节二进制数转换成 3 位非压缩型BCD码。 设一个字节二进制数在内部RAM 40H单元, 转换结果放入内 部 RAM 50H#, 51H, 52H单元中(高位在前), 程序如下:
例 15 在一个温度检测系统中, 温度模拟信号由 10 位A/D 输入。将A/D结果转换为对应温度值, 可采用查表方法实现。 先由实验测试出整个温度量程范围内的A/D转换结果, 把A/D 转换结果 000H~ 3FFH所对应的温度值组织为一个表存储在
程序存储器中, 那么就可以根据检测到的模拟量的 A/D转换
值查找出相应的温度值。 设测得的A/D转换结果已存入 20H#, 21H单元中(高位 字节在20H中, 低位字节在21H中), 查表得到的温度值存放 在22H#,23H单元(高位字节在 22H中, 低位字节在23H中)。
程序如下: FTMP: MOV DPTR, #TAB CLRC RLCA ; DPTR←表首地址 MOVA, 21H ; (20H)(21H)×2
MOVX @DPTR, A ; 存大数
RET
BIG2: MOVX A, @DPTR; 第二个数大
SJMP BIG1 RET
例 5 工作单元清零。 在应用系统程序设计时 , 有时经常需要将存储器中各部 分地址单元作为工作单元 , 存放程序执行的中间值或执行结 果, 工作单元清零工作常常放在程序的初始化部分中。 设有50个工作单元, 其首址为外部存储器8000H单元, 则
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
相关文档
最新文档