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
各位大哥看下~~
王爽编的《汇编语言》第八章实验 调试时候出现 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 指...