MASM 在输入负小数时给出不正确的结果
MASM giving incorrect results upon entering negative decimals
因此,我正在编写一个程序来除以两个负整数并存储商和余数,但它显示的结果不正确。
这是我的代码:
mov eax, input1
mov edx, 0 ; dividend high half = 0. prefer xor edx,edx
mov ebx, input2 ; divisor can be any register or memory
div ebx
mov remainder, edx
mov edx, offset prompt
call Writestring
mov quotient, eax
call WriteDec
mov edx, offset prompt1
call Writestring
mov edx, remainder
call WriteDec
call Crlf
div
用于无符号除法。对于带符号的除法,您需要 idiv
. This takes a signed 64-bit dividend in edx:eax
, so you don't want edx
to be zero if the dividend is negative; rather, you want to sign extend eax
into edx
. This can be done with cdq
.
所以我想你想要
mov eax, input1
cdq
mov ebx, input2
idiv ebx
mov remainder, edx
mov quotient, eax
...
另外几点:
WriteDec
希望在哪里找到要写入的数字?检查其文档。您似乎没有将结果放入任何一致的寄存器中。
您正在等到调用 Writestring
之后将 eax
的商保存到内存中。您确定 Writestring
不会覆盖 eax
吗?许多调用约定将允许它。
如果 input2
为 0,或者如果 input1
为 0x80000000
(最负的 32 位整数)并且input2
是 -1
。如果您还没有在其他地方进行输入检查,您可能需要进行一些输入检查。
正如您的评论所说,idiv
可以从寄存器或内存中获取其操作数。所以当你可以简单地做 idiv input2
时,就不需要 mov ebx, input2
。 (虽然你可能还想设计你的程序,使 input2
一直存在于寄存器中,并且从一开始就不需要存储在内存中。)
因此,我正在编写一个程序来除以两个负整数并存储商和余数,但它显示的结果不正确。 这是我的代码:
mov eax, input1
mov edx, 0 ; dividend high half = 0. prefer xor edx,edx
mov ebx, input2 ; divisor can be any register or memory
div ebx
mov remainder, edx
mov edx, offset prompt
call Writestring
mov quotient, eax
call WriteDec
mov edx, offset prompt1
call Writestring
mov edx, remainder
call WriteDec
call Crlf
div
用于无符号除法。对于带符号的除法,您需要 idiv
. This takes a signed 64-bit dividend in edx:eax
, so you don't want edx
to be zero if the dividend is negative; rather, you want to sign extend eax
into edx
. This can be done with cdq
.
所以我想你想要
mov eax, input1
cdq
mov ebx, input2
idiv ebx
mov remainder, edx
mov quotient, eax
...
另外几点:
WriteDec
希望在哪里找到要写入的数字?检查其文档。您似乎没有将结果放入任何一致的寄存器中。您正在等到调用
Writestring
之后将eax
的商保存到内存中。您确定Writestring
不会覆盖eax
吗?许多调用约定将允许它。如果
input2
为 0,或者如果input1
为0x80000000
(最负的 32 位整数)并且input2
是-1
。如果您还没有在其他地方进行输入检查,您可能需要进行一些输入检查。正如您的评论所说,
idiv
可以从寄存器或内存中获取其操作数。所以当你可以简单地做idiv input2
时,就不需要mov ebx, input2
。 (虽然你可能还想设计你的程序,使input2
一直存在于寄存器中,并且从一开始就不需要存储在内存中。)