【发布时间】:2020-10-17 12:52:22
【问题描述】:
如标题中所述,我需要使此代码能够执行与仅使用 16 位相同的操作,但将 .386 添加到代码中,以便我可以使用 32 位寄存器。但是当我现在添加 .386 时,我的代码没有打印任何东西,知道如何解决这个问题。我的 mov 作为 @data 有问题还是我需要添加其他内容?我正在使用 TASM
TITLE Programa de prueba(prueba.asm)
.386
.model small
.stack
.data
escoga db 10,13,7, 'Escoga la operacion: 1. x and y, 2. x or y, 3. not x, 4. x xor y, 5. terminar:
', '$'
digite1 db 10,13,7, 'Digite el primer numero hexadecimal: ', '$'
digite2 db 10,13,7, 'Digite el segundo numero hexadecimal: ', '$'
Yval db "Enter Y hexadecimal value: ",0
resultStr db "The result is: ",0
result db ?
x db 8 DUP(' '),'$'
y db 8 DUP(' '),'$'
num db 1 DUP(0),'$'
.code
main proc
mov ax, @data
mov ds, ax
.loop1:
cmp si, 82
je .done1
mov ah, 0Eh
mov al, escoga[SI]
mov bh, 00h
int 10h
inc si
jmp .loop1
.done1:
mov si, 0
mov di, 0
.inp1:
cmp si, 1
je .ext1
mov ah, 00h
int 16h
inc si
inc di
jmp .modi1
.modi1:
mov num[di], al
mov ah, 0Eh
mov al, num[di]
mov bh, 00h
int 10h
jmp .inp1
.ext1:
mov si, 0
.ext2:
cmp si, 2
je .salir
mov ah, 0Eh
mov al, num[SI]
inc si
jmp .ext2
.salir:
cmp num[SI-1], '5'
jge .term
jmp .term2
.term2:
mov si, 0
.loop2:
cmp si, 40
je .done2
mov ah, 0Eh
mov al, digite1[SI]
mov bh, 00h
int 10h
inc si
jmp .loop2
.done2:
mov si, 0
mov di, 0
.inp2:
cmp si, 8
je .ext3
mov ah, 00h
int 16h
inc si
inc di
jmp .modi2
.modi2:
mov x[di], al
mov ah, 0Eh
mov al, x[di]
mov bh, 00h
int 10h
jmp .inp2
.ext3:
mov si, 0
mov di, 0
.loop3:
cmp si, 41
je .done3
mov ah, 0Eh
mov al, digite2[SI]
mov bh, 00h
int 10h
inc si
jmp .loop3
.done3:
mov si, 0
mov di, 0
.inp3:
cmp si, 8
je .ext4
mov ah, 00h
int 16h
inc si
inc di
jmp .modi3
.modi3:
mov y[di], al
mov ah, 0Eh
mov al, y[di]
mov bh, 00h
int 10h
jmp .inp3
.ext4:
mov si, 0
mov di, 0
.term:
.exit
main endp
end main
【问题讨论】:
-
为什么你的
.loop1循环使用si,而此时你还没有初始化si? -
你就在那里,但它仍然使用 si 就好像它有 0
-
如果将
.386放在.model small之后而不是之前会发生什么,所以将其更改为.model small.386 -
是的,您将能够在 16 位代码中使用 32 位寄存器。
标签: assembly x86 32-bit tasm real-mode