实验7就是练习寻址方式的使用,代码的注释中写了思路和注释,很清楚。
Power idea 公司从1975年成立一直到1995年的基本情况如下:
代码如下:
assume cs:code,ds:data,ss:stack
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个字符串 year,每个year占4个字节,21*4=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数据 sum 84=21*4
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 summ ne ?? ')
table ends
stack segment
db 128 dup(0)
stack ends
code segment
start:
mov ax,stack
mov ss,ax
mov sp,128 ;初始化栈
;bx,si,di,bp 四个寄存器用于访问内存
;table段访问方式:bp:0-21(0-3存放year,5-8存放总收入,10-11存放人数,12-14人均收入) + 21
mov ax,table
mov es,ax
;data中:si访问年,di访问总收入,bx访问员工数量
;table中:bp访问
mov ax,data
mov ds,ax
mov si,0 ;访问year
mov di,21*4 ;访问年收入
mov bx,21*4+21*4 ;访问总人数
mov ax,table
mov es,ax
mov bp,0
mov cx,21 ;访问次数
inputTable:
; 移动年份 0-3存放year
push [si+0]
pop es:[bp+0]
push [si+2]
pop es:[bp+2]
;移动总收入 5-8存放总收入
mov ax,[di+0] ;低位
mov dx,[di+2] ;高位
mov es:[bp+5],ax
mov es:[bp+7],dx
;移动人数 10-11存放人数,
push [bx]
pop es:[bp+0ah]
;移动人平均收入12-14人均收入
div word ptr es:[bp+0ah]
mov es:[bp+0dh],ax
;data中:si访问年,di访问总收入,bx访问员工数量
;table中:bp访问
add si,4
add di,4
add bx,2
add bp,16h
loop inputTable
mov ax,4c00h
int 21h
code ends
end start