在汇编时写一个字符串输入反向

时间:2017-01-18 22:23:16

标签: assembly input x86 dos

这是我迄今为止所做的事情

 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),但我不知道如何得到它。

1 个答案:

答案 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],0lea之后)。

当您输入字符串" AAAB"时,DOS将在内存中返回:

FF 04 41 41 41 42 0D 24 24 24 ...

正如您所看到的,您可以读取L2字节以获得没有CR的字符串的实际长度,或者您可以在缓冲区中对strlen进行13函数扫描。

我不确定问题是什么,如果有问题,但你说你不知道,上面的内容应该至少给你两个想法如何继续。

作为旁注,请停止使用无意义的标签,这样就很难阅读来源"以及您将在大多数时间做的事情。

此外,当文档检查失败时,您可以尝试在调试器中对其进行反向工程。例如,int 21h调用后的内存内容有点自我解释(但我仍然更喜欢先检查文档)。然而你应该能够在int 21h之后断点并查看记忆。如果你不是,你做错了,得到一些调试器+学习如何使用它。