Asm程序不提供输出

时间:2017-02-11 23:24:22

标签: assembly x86 dos

仍然关于我的项目,我试图打印一个数组,没有任何反应......没有错误或任何事情,唯一发生的事情是用户可以输入9个字符,它,程序完成 程序需要在0到9之间得到9个数字并分成组 a,b和c

MODEL small
STACK 100h
DATASEG
Welcome db "Welcome, please enter 9 numbers between 0 and 9: $"
MainArr db 9 dup(0)
Aarr db 9 dup(0)
Barr db 9 dup(0)
Carr db 9 dup(0)
AarrLength db ?
BarrLength db ?
CarrLength db ?
CODESEG
start:
mov ax, @data
mov ds, ax

mov dx, offset Welcome
mov ah, 9
int 21h
xor di, di
xor bx, bx
mov si, 0
mov cx, 0
jmp gettingInput
gettingInput:
inc cx
cmp cx, 10
je continue
mov ah, 1h
int 21h
mov [MainArr+si], al
inc si
cmp al, 8
jge zoneA
cmp al, 6
jb zoneC
jmp zoneB

zoneA: 
mov [Aarr+bx],al
inc bx
jmp gettingInput

zoneB: 
mov [Barr+si],al
inc si
jmp gettingInput

zoneC: 
mov [Carr+di],al
inc di
jmp gettingInput

continue:

mov cx, 9
xor ax, ax
mov si, offset Aarr
findLengthA:
cmp [si], 0
je foundLength
inc ax
loop findLengthA

foundLengthA:
mov [AarrLength], al 

mov cx, 9
xor ax, ax
mov si, offset Barr
findLengthB:
cmp [si], 0
je foundLength
inc ax
loop findLengthB

foundLengthB:
mov [BarrLength], al 


mov cx, 9
xor ax, ax
mov si, offset Carr
findLengthC:
cmp [si], 0
je foundLength
inc ax
loop findLengthC

foundLength:
mov [CarrLength], al 


mov bl, AarrLength
mov bh, 0
inc bx
inc bx
mov [offset Aarr + bx], '$'
mov si, offset Aarr
printA:
mov ah, 9h
mov dx, offset Aarr
int 21


exit:
mov ax, 4c00h
int 21h
END start

2 个答案:

答案 0 :(得分:0)

我怀疑问题出在您的zoneA,B,C区域。您似乎依赖寄存器来保存数组的长度。我建议您在每个区域中加载并存储实际的数组长度变量。您还在主阵列中使用si,因此我非常确定这是一个错误。

答案 1 :(得分:0)

您忘记了输入是一个字符。然而,你比较它似乎是一个小值!

mov ah, 1h
int 21h
mov [MainArr+si], al
inc si
cmp al, "8"      <--- Compare as character
jge zoneA
cmp al, "6"      <--- Compare as character
jb zoneC
jmp zoneB

由于此错误,所有数据都落在 Aarr 中。幸运的是,因为其他错误! 请注意:

  • zoneA得到&#34; 8&#34;,&#34; 9&#34;
  • zoneB得到&#34; 6&#34;,&#34; 7&#34;
  • zoneC获取&#34; 0&#34;,&#34; 1&#34;,&#34; 2&#34;,&#34; 3&#34;,&#34; 4&#34;, &#34; 5&#34;

这看起来不是你想要的,看看你之前的问题!!!

je foundLength

在A和B情况下,您需要分别分支到 foundLengthA foundLengthB

您不能同时使用SI寄存器同时处理 MainArr Barr ! 使用

  • 像@AustinHastings这样的变量建议
  • 或者使用BP注册,并使用明确的段覆盖mov [ds:Barr+bp], al inc bp

显示 Aarr 数组的方式存在多个问题。这是正确的方法:

mov  bl, AarrLength
mov  bh, 0              <--- No need to use INC BX twice
mov  [Aarr + bx], '$'
mov  ah, 09h
mov  dx, offset Aarr
int  21h                <--- Don't forget the "h" for hexadecimal

为了确保在3个阵列中的每个阵列中搜索终止零点成功,请将存储设置为10个字节。如果所有9个输入进入同一个数组,您仍然会找到终止零。

Aarr db 10 dup(0)
Barr db 10 dup(0)
Carr db 10 dup(0)