assume cs:codesg
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'
;以上是表示21年的21个字符串
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
;以上是表示21年公司总收入的21个dword型数据
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430,15257,17800
;以上是表示21年公司雇员人数的21个word型数据
data ends
table segment
db 21 dup ('year summ ne ?? ')
table ends
codesg segment
start: mov ax,data
mov ds,ax
mov di,0
mov ax,table
mov es,ax
mov bx,0
mov cx,21
s: mov ax,ds:[di] ;年份
mov es:[bx],ax
mov ax,ds:[di+2]
mov es:[bx+2],ax
mov ax,ds:[di+168] ;雇员
mov es:[bx+10],ax
mov ax,ds:[di+84] ;总收入
mov es:[bx+5],ax
mov dx,ds:[di+86]
mov es:[bx+7],dx
div word ptr ds:[di+168] ;人均收入
mov es:[bx+13],ax
add di,4
add bx,16
loop s
mov ax,4c00h
int 21h
codesg ends
end start
编译通过,运行显示divide overflow ,是哪里出错了?
------解决方案--------------------------------------------------------
你的逻辑有问题!
di定位2种类型 总工资DD类型和雇员人数DW类型,怎么可能对呢?
一种办法是di定位table,每次 add di,16
而把dx分为dh和dl,前者定位DD,后者定位DW
或者你用一个内存变量来做索引也可,总之随你。