汇编语言编程序

一、求两个32位有符号数DATA1和DATA2的和。若计算正确结果小于最小负数,则将最小负数存入SUM单元中;若计算正确结果大于最大正数,则将最大正数存入SUM单元中;否... 一、 求两个32位有符号数DATA1和DATA2的和。若计算正确结果小于最小负数,则将最小负数存入SUM单元中;若计算正确结果大于最大正数,则将最大正数存入SUM单元中;否则将计算结果存入SUM单元中。用汇编语言编写 一定可以运行的那种 可以发到我邮箱 重谢 展开
 我来答
帐号已注销
2012-12-23 · TA获得超过3000个赞
知道大有可为答主
回答量:1338
采纳率:75%
帮助的人:1300万
展开全部
首先,你要明白:
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的值看下结果。
更多追问追答
追问
额   我们学的是汇编语言   8086/8088 系统   虽然我不是很精通 但是感觉和我们平常用的语句不太一样   有符合我们学的吗   能不能再实现一下键盘输入啊
追答
键盘输入不是汇编的特长,要想用键盘输入数字,不是一般的麻烦。
对于这道题,想在8086里输入32位数,是不可能的。
要想做输入请用C/C++。
下面是按8086的格式改的。

dseg segment
;DATA1 dd 81234567h
DATA1 dd 7fffffffh; 最大正数
DATA2 dd 80000000h; 最小负数
;DATA2 dd 1234; 最小负数
SUM dd ?
dseg ends

cseg segment
assume cs:cseg, ds:dseg
start:
mov ax, dseg
mov ds, ax

mov ax, word ptr DATA1
mov bx, word ptr DATA2
mov dx, word ptr [DATA1 + 2]
mov cx, word ptr [DATA2 + 2]

add ax, bx
adc dx, cx
jo OverFlow
jmp Done

OverFlow:
cmp word ptr [DATA1 + 2], 0
jg PlusOverFlow
mov dx, 8000h
mov ax, 0 ;最小负数
jmp Done

PlusOverFlow:
mov dx, 7fffh
mov ax, 0ffffh ;最大正数

Done:
mov word ptr SUM, ax
mov word ptr [SUM + 2], dx

mov ah, 4ch
int 21h
cseg ends
end start
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式