汇编语言编程序一、 求两个32位有符号数DATA1和DATA2的和.若计算正确结果小于最小负数,则将最小负数存入SUM单元中;若计算正确结果大于最大正数,则将最大正数存入SUM单元中;否
来源:学生作业帮助网 编辑:六六作业网 时间:2025/01/12 16:31:39
汇编语言编程序一、 求两个32位有符号数DATA1和DATA2的和.若计算正确结果小于最小负数,则将最小负数存入SUM单元中;若计算正确结果大于最大正数,则将最大正数存入SUM单元中;否
汇编语言编程序
一、 求两个32位有符号数DATA1和DATA2的和.若计算正确结果小于最小负数,则将最小负数存入SUM单元中;若计算正确结果大于最大正数,则将最大正数存入SUM单元中;否则将计算结果存入SUM单元中.用汇编语言编写 一定可以运行的那种 可以发到我邮箱 重谢
汇编语言编程序一、 求两个32位有符号数DATA1和DATA2的和.若计算正确结果小于最小负数,则将最小负数存入SUM单元中;若计算正确结果大于最大正数,则将最大正数存入SUM单元中;否
首先,你要明白:
1. 一个正数和一个负数相加,结果肯定不会溢出,即结果既不会大于最大正数,也不会小于最小负数;同样道理,两个正数或两个负数相减,结果肯定也不会溢出.另外还有一种特殊情况,即当DATA1为0,DATA2为最小负数的时候,DATA1 - DATA2也会溢出.
2. 若结果大于最大正数,肯定是两个正数相加;若结果小于最小负数,则肯定是两个负数相加;
3. 溢出标志只能判断是否溢出,而不能判断是正溢出,还是负溢出.所以应该先判断OF标志位,若有溢出,接着判断DATA1或者是DATA2的符号,若为正数,则为正溢出;否则为负溢出.
程序如下,我是按在386上编的.
.model small
.386
.dosseg
.stack 1024
.data
;DATA1 dd 81234567h
DATA1 dd 7fffffffh; 最大正数
DATA2 dd 80000000h; 最小负数
;DATA2 dd 1234;
SUM dd ?
.code
.startup
mov eax, DATA1
add eax, DATA2
jo OverFlow
jmp Done
OverFlow:
cmp DATA1, 0
jg PlusOverFlow
mov eax, 80000000h ;最小负数
jmp Done
PlusOverFlow:
mov eax, 7fffffffh ;最大正数
Done:
mov SUM, eax
.exit
end
你可以修改下DATA1和DATA2的值看下结果.