王爽编的《汇编语言》第八章实验 调试时候出现 divide overflow

assume cs:table ds:data ss:c es:d
data segment
db '1975','1976','1977','1978','1979','1980','1981','1982','1983','1984'
db '1985','1986','1987','1988','1989','1990','1991','1992','1993'
data ends
c segment
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417
dd 197514,345980,590827,803530,1183000,1843000,2759000,3753000
c ends
d segment
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430
d ends
table segment
db 19 dup ('year summ ne ?? ')
start:
mov bx,0
mov si,0
mov di,0
mov cx,19
s:
mov ax,data
mov ds,ax
mov ax,ds:[si]
mov cs:[bx],ax
mov ax,ds:[si+2]
mov cs:[bx+2],ax
mov ax,c
mov ds,ax
mov ax,ds:[si+4]
mov cs:[bx+5],ax
mov ax,ds:[si+6]
mov cs:[bx+7],ax
mov ax,d
mov ds,ax
mov ax,ds:[di]
mov cs:[bx+10],ax
mov dx,cs:[bx+5]
mov ax,cs:[bx+7]
div word ptr cs:[bx+10]
mov cs:[bx+13],ax
add bx,0010h
add si,0004h
add di,0002h
loop s
mov ax,4c00h
int 21h
table ends
end start
各位大哥看下~~

你这个程序的逻辑性太差了,第一个问题在
mov ax,ds:[si+4]
mov cs:[bx+5],ax
mov ax,ds:[si+6]
mov cs:[bx+7],ax
这里设置收入的时候不是+4,+6,上面应该是mov ax,ds:[si]:
mov ax,ds:[si+2],因为只占用了2个字空间,不知道你+4,+6的愿意是什么
第二个问题,就是影响你除法divide overflow的关键
mov ax,c
mov ds,ax
mov ax,ds:[di]
mov cs:[bx+10],ax
mov dx,cs:[bx+5]
mov ax,cs:[bx+7]
div word ptr cs:[bx+10]
做div的时候如果是8为除法,被除数应该是在AX中,16为除法,被除数高位应该在DX,地位在AX中,你看你上面的代码,你是低位在Dx中,高位在ax中,弄反过来了,改成mov dx,cs:[bx+7],mov ax,cs:[bx+5]就可以了

我调试过了,你的程序只要改这2个地方就能够正常得到预期答案了.

附上我自己以前写的这个程序,首先声明,逻辑性也是很差的,大家共同参考:

assume cs:code,ds:data
data segment
db '1975','1976','1977','1978','1979','1980','1981','1982','1983'
db '1984','1985','1986','1987','1988','1989','1990','1991','1992'
db '1993','1994','1995'
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430,15257,17800
data ends
table segment
db 21 dup('year sume ne ?? ')
table ends
code segment
start: mov ax,data
mov ds,ax
mov ax,table
mov es,ax
mov bx,0
mov si,0
mov di,168
mov cx,21
s: mov ax,[bx]
mov es:[si],ax
mov ax,[bx+2]
mov es:[si+2],ax
mov ax,[bx+84]
mov es:[si+5],ax
mov ax,[bx+84+2]
mov es:[si+5+2],ax
mov ax,[di]
mov es:[si+0ah],ax
mov ax,[bx+84]
mov dx,[bx+84+2]
mov bp,[di]
div bp
mov es:[si+0dh],ax
add bx,4
add di,2
add si,10h
loop s
mov ax,4c00h
int 21h
code ends
end start
温馨提示:内容为网友见解,仅供参考
第1个回答  2009-07-27
这个算法很垃圾。

这个问题已经有人提过,我已作答。请参见下方的参考资料。

参考资料:http://zhidao.baidu.com/question/107131814.html

第2个回答  2009-07-27
除法溢出了

王爽编的《汇编语言》第八章实验 调试时候出现 divide overflow
做div的时候如果是8为除法,被除数应该是在AX中,16为除法,被除数高位应该在DX,地位在AX中,你看你上面的代码,你是低位在Dx中,高位在ax中,弄反过来了,改成mov dx,cs:[bx+7],mov ax,cs:[bx+5]就可以了 我调试过了,你的程序只要改这2个地方就能够正常得到预期答案了.附上我自己以前写...

汇编语言DIV指令相关
CPU 执行除法指令(如:DIV CX、DIV BL)时,是有可能溢出的。如果被除数较大,或除数较小,都可能使“商”超出预定位数,此时,就会溢出。特别是当除数为零时,必然会出现:Divide overflow。直接使用 DIV 指令,有一定的风险,一不小心就溢出了。特别是数字不明确的时候。因此,在执行 DIV 指...

相似回答
大家正在搜