问题描述
我试图让这段代码反转“Taco”这个词,但我不明白为什么结果中的最后一个字母总是出错。 (它不断输出“ocac”) 我还希望用户写“Taco”作为输入,这就是我在开始时使用 INT 21H 的原因。
我尝试使用不同的值,例如 [SI+3]、[SI+2],只是为了了解发生了什么,但我无法弄清楚。
是否可以使用 LEA 来完成这项工作?
.model small
.stack 32
.data
VALUE DB 51 DUP('$')
RE LABEL BYTE
MAXLEN DB 50
ACTLEN DB ?
ARR DB 51 DUP('$')
.code
MAIN proc FAR
;Load Data;
MOV AX,@data
MOV DS,AX
;Get input
MOV AH,0AH
LEA DX,RE
INT 21H
;Load Pointers to arrays
LEA SI,ARR
LEA BX,VALUE
;Setup CX register for loop.
MOV CX,0
MOV CL,ACTLEN
AGAIN:
MOV AX,[SI+4] ;+4 because "Taco" has 4 letters.
MOV [BX],AX ;Moving character to resulting array
INC BX ;Move new array to next index
SUB SI,1 ;Move original array to prevIoUs index.
LOOP AGAIN
;Clearing last line
MOV AX,0601H
MOV BH,70H
INT 10H
;Printing resulting array on screen
LEA DX,VALUE
MOV AH,09H
INT 21H
;Termination
MOV AX,4C00H
INT 21H
MAIN endp
END MAIN
谁决定花时间回答这个问题,我非常感谢!
解决方法
正如 Peter Cordes 所提到的,AX 处理的是 2 个字节。我把它切换到 AL,这样它只处理 1 个字节,最后得到“ocaT”
我还将 [SI+4] 更改为 [SI+3],以便它正确指向输入数组的最后一个字符,而不是之后。
AGAIN:
MOV AL,[SI+3] ;changed
MOV [BX],AL ;changed
INC BX
SUB SI,1
LOOP AGAIN
现在效果很好!