可以用emu8086或者debug查看运行结果,以下是我的代码:
assume cs:codesg,ds:datasg,ss:stacksg
datasg 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个字符串,共占84个字节
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型数据,共占84个字节
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8228
dw 11542,14430,15257,17800
;以上表示21年公司雇员人数的21个word型数据,共占42个字节
datasg ends
table segment
db 21 dup ('year summ ne ?? ')
table ends
stacksg segment
dw 0,0,0,0,0,0,0,0
stacksg ends
codesg segment
start: mov ax,datasg ;段寄存器初始化
mov ds,ax
mov ax,table
mov es,ax
mov ax,stacksg
mov ss,ax
mov sp,16
mov bx,0 ;基址寻址寄存器初始化
mov si,0 ;源变址
mov di,0 ;目的变址
mov bp,0 ;源变址
mov cx,21
s: push cx
mov cx,2
s0: mov ax,ds:[bp] ;循环复制年份4字节
mov es:[bx+di],ax
add di,2
add bp,2
loop s0
sub bp,4 ;因为bp加上了4字节,此处减去4字节
mov di,0
mov ax,ds:[bp+84] ;复制收入2字节,低位放在ax寄存器
mov es:[bx+5+di],ax
add di,2
add bp,2
mov dx,ds:[bp+84] ;固执收入2字节,高位放在dx寄存器
mov es:[bx+5+di],dx
div word ptr [si+168] ;求平均收入(要注意除数位数)
mov es:[bx+13],ax
mov ax,[si+168] ;复制人数
mov es:[bx+10],ax
mov di,0
add bx,16 ;下一条记录
add si,2
add bp,2 ;恢复bp
pop cx
loop s
mov ax,4c00h
int 21h
codesg ends
end start