这是我迄今为止所做的事情
Data Segment
str1 db 'String_Reverse','$'
strlen1 dw $-str1
strrev db 20 dup(' ')
MSG1 DB 10,13,'ENTER ANY STRING :- $'
MSG2 DB 10,13,'ENTERED STRING IS :- $'
MSG3 DB 10,13,'REVERSED STRING IS : $'
MSG4 DB 10,13,'REVERSED STRING IS : $'
P1 LABEL BYTE
M1 DB 0FFH
L2 DB ?
P11 DB 0FFH DUP ('$')
Data Ends
CUCU MACRO MSG ;MACRO care afiseaza un mesaj dorit
MOV AH,9
LEA DX,MSG
INT 21H
ENDM
Code Segment
Assume cs:code, ds:data
Begin:
MOV AX,DATA
MOV DS,AX
CUCU MSG1 ;afisare msg1
LEA DX,P1
MOV AH,0AH
INT 21H
CUCU MSG2 ; afisare msg2
CUCU P11 ; afisare string introdus
CUCU MSG3
mov ax, data
mov ds, ax
mov es, ax
mov cx, strlen1
add cx, -2
lea si, P11
lea di, strrev
add si, strlen1
add si, -2
L1:
mov al, [si]
mov [di], al
dec si
inc di
loop L1
mov al, [si]
mov [di], al
inc di
mov dl, '$'
mov [di], dl
Print:
mov ah, 09h
lea dx, strrev
int 21h
Exit:
mov ax, 4c00h
int 21h
Code Ends
End Begin
此刻我有str1并反向显示,但我需要反向显示P11变量,这是我从键盘上得到的。从我到目前为止看到的我需要strlen(P11),但我不知道如何得到它。
答案 0 :(得分:1)
LEA DX,P1
MOV AH,0AH
INT 21H
这是您的数据来源。那你为什么不检查documentation about it?
在M1
调用内存之前(BTW,为什么有两个标签,两者都无意义?)包含:
FF ?? 24 24 24 24 24 ...
(0x24 '$'
个字节中的255个)。
??
,我建议在int调用之前将其设置为0
,因为您没有提供任何"之前的输入数据"。 mov byte ptr[dx+1],0
(lea
之后)。
当您输入字符串" AAAB"时,DOS将在内存中返回:
FF 04 41 41 41 42 0D 24 24 24 ...
正如您所看到的,您可以读取L2
字节以获得没有CR的字符串的实际长度,或者您可以在缓冲区中对strlen
进行13
函数扫描。
我不确定问题是什么,如果有问题,但你说你不知道,上面的内容应该至少给你两个想法如何继续。
作为旁注,请停止使用无意义的标签,这样就很难阅读来源"以及您将在大多数时间做的事情。
此外,当文档检查失败时,您可以尝试在调试器中对其进行反向工程。例如,int 21h
调用后的内存内容有点自我解释(但我仍然更喜欢先检查文档)。然而你应该能够在int 21h
之后断点并查看记忆。如果你不是,你做错了,得到一些调试器+学习如何使用它。