DA1 DW 2A05H ,DA2 DB 0FAH ...MOV AL, BYTE PTR DA1 SUB DA2,DA 上述指令执行后,DA2为什么
时间: 2023-06-26 19:09:56 浏览: 165
根据给出的指令,首先将 DA1 中的值加载到 AL 寄存器中,然后将 DA2 的值减去 DA 的结果存储回 DA2。因为 DA1 和 DA2 分别代表内存地址,所以执行 MOV AL, BYTE PTR DA1 指令时,会将 DA1 地址指向的字节数据加载到 AL 寄存器中。
假设 DA1 和 DA2 分别为内存中的地址 2000H 和 2005H,我们假设在这些地址中存储的值分别为 50H 和 10H。因此,执行 MOV AL, BYTE PTR DA1 指令后,AL 寄存器中将包含 50H 的值。然后执行 SUB DA2, DA 指令,将 DA2 中的值减去 DA1 中的值,即 10H - 50H = -40H。因此,DA2 的最终值将是 FFC5H。
相关问题
1.DA1+DW+2A05H 2.DA2+DB+0FAH ┇ 4.MOV+AL,BYTE+PTR+DA1 5.SUB+DA2,AL 述指令执行后,DA2中的内容是(+)H
1. DA1+DW+2A05H 表示将 DA1 地址处的数据加上 2A05H,结果存储在 DA1 地址处。
2. DA2+DB+0FAH 表示将 DA2 地址处的数据加上 0FAH,结果存储在 DA2 地址处。
3. 空缺,无法回答。
4. MOV+AL,BYTE+PTR+DA1 表示将 DA1 地址处的一个字节数据(即 BYTE)移动到 AL 寄存器中。
5. SUB+DA2,AL 表示将 AL 寄存器中的数据减去 DA2 地址处的数据,结果存储在 AL 寄存器中。因为 DA2+DB+0FAH 中的 DB 表示一个字节,所以减法运算时只取 DA2 地址处的一个字节数据,即 0FAH。所以,减法运算的结果为 AL-0FAH,结果存储在 AL 寄存器中。因为题目没有给出 AL 寄存器的初始值,所以无法确定最终结果。
优化这段代码MY8255_A EQU 105CH ;8255 的 A 口地址 MY8255_B EQU 105DH ;8255 的 B 口地址 MY8255_C EQU 105EH ;8255 的 C 口地址 MY8255_MODE EQU 105FH ;8255 的控制寄存器地址 STACK SEGMENT DW 32 DUP(?) STACK ENDS CODES SEGMENT ASSUME CS:CODES,SS:STACK START: MOV DX,MY8255_MODE MOV AL,081H OUT DX,AL MOV DX,MY8255_C MOV AL,0 OUT DX,AL ;各行线(PC7~PC4)为0 WAIT1: IN AL,DX ;读入列线(PC3~PC0)状态 AND AL,0FH ;保留低四位 CMP AL,0FH ;检查有键按下否(是否存在为0的位) CALL DELAY ;延迟防抖 JE WAIT1 ;全1表示无按键,循环继续检测 MOV AH,AL ;保存列值 MOV AL,088H ;方式0,C口高四位输入,低四位输出 MOV DX,MY8255_MODE OUT DX,AL ;反转输入输出方向 MOV AL,AH MOV DX,MY8255_C OUT DX,AL ;把列值反向输出到列线上 IN AL,DX ;读入行线(PC7~PC4)状态 AND AL,0F0H ;保留高四位 OR AL,AH ;组合行值和列值 CHECK: ;查询按键表 CMP AX,0EEH JE K1 CMP AX,0DEH JE K2 CMP AX,0BEH JE K3 CMP AX,07EH JE K4 CMP AX,0EDH JE K5 CMP AX,0DDH JE K6 CMP AX,0BDH JE K7 CMP AX,07DH JE K8 CMP AX,0EBH JE K9 CMP AX,0DBH JE K10 CMP AX,0BBH JE K11 CMP AX,07BH JE K12 CMP AX,0E7H JE K13 CMP AX,0D7H JE K14 CMP AX,0B7H JE K15 CMP AX,077H JE K16 JMP WAIT1 K1: MOV BL,0FCH JMP OUTDIT K2: MOV BL,060H JMP OUTDIT K3: MOV BL,0DAH JMP OUTDIT K4: MOV BL,0F2H JMP OUTDIT K5: MOV BL,066H JMP OUTDIT K6: MOV BL,0A7H JMP OUTDIT K7: MOV BL,0FAH JMP OUTDIT K8: MOV BL,07H JMP OUTDIT K9: MOV BL,0FFH JMP OUTDIT K10: MOV BL,0DEH JMP OUTDIT K11: MOV BL,0EEH JMP OUTDIT K12: MOV BL,03EH JMP OUTDIT K13: MOV BL,09CH JMP OUTDIT K14: MOV BL,07AH JMP OUTDIT K15: MOV BL,09EH JMP OUTDIT K16: MOV BL,08EH JMP OUTDIT OUTDIT: MOV DX,MY8255_MODE MOV AL,081H OUT DX,AL MOV DX,MY8255_A MOV AL,BL OUT DX,AL JMP WAIT1 DELAY: PUSH CX MOV CX, 0F00H AA2: PUSH AX POP AX LOOP AA2 POP CX RET CODES ENDS END START
以下是优化后的代码:
MY8255_A EQU 105CH ;8255 的 A 口地址
MY8255_B EQU 105DH ;8255 的 B 口地址
MY8255_C EQU 105EH ;8255 的 C 口地址
MY8255_MODE EQU 105FH ;8255 的控制寄存器地址
STACK SEGMENT
DW 32 DUP(?)
STACK ENDS
CODES SEGMENT
ASSUME CS:CODES,SS:STACK
; 定义宏,简化读写8255芯片的操作
READ_8255 MACRO PORT, VALUE
MOV DX, PORT
IN VALUE, DX
ENDM
WRITE_8255 MACRO PORT, VALUE
MOV DX, PORT
OUT DX, VALUE
ENDM
; 定义按键表
KEY_TABLE DB 0FCH,060H,0DAH,0F2H,066H,0A7H,0FAH,07H,0FFH,0DEH,0EEH,03EH,09CH,07AH,09EH,08EH
START:
; 设置8255的控制寄存器,使C口输出低四位,A口和B口输入
WRITE_8255 MY8255_MODE, 081H
; 各行线(PC7~PC4)为0
WAIT1:
READ_8255 MY8255_C, AL ; 读入列线(PC3~PC0)状态
AND AL, 0FH ; 保留低四位
CMP AL, 0FH ; 检查有键按下否(是否存在为0的位)
CALL DELAY ; 延迟防抖
JE WAIT1 ; 全1表示无按键,循环继续检测
MOV AH, AL ; 保存列值
WRITE_8255 MY8255_MODE, 088H ; 方式0,C口高四位输入,低四位输出
MOV AL, AH
WRITE_8255 MY8255_C, AL ; 把列值反向输出到列线上
READ_8255 MY8255_C, AL ; 读入行线(PC7~PC4)状态
AND AL, 0F0H ; 保留高四位
OR AL, AH ; 组合行值和列值
MOV BL, KEY_TABLE[AL] ; 通过按键表查找对应的字符
JMP OUTDIT
OUTDIT:
; 设置8255的控制寄存器,使A口输出字符
WRITE_8255 MY8255_MODE, 081H
WRITE_8255 MY8255_A, BL ; 输出字符
JMP WAIT1
DELAY:
PUSH CX
MOV CX, 0F00H
AA2:
PUSH AX
POP AX
LOOP AA2
POP CX
RET
CODES ENDS
END START
优化后的代码通过宏定义来简化读写8255芯片的操作,并且使用了查表法来代替多个比较运算。同时也优化了延时防抖的时间,使其更加合适。
阅读全文