实验7:寻址方式在结构化数据访问中的应用
Power idea公司从1975年成立一直到1995年的基本情况如下。
年份 | 收入(千美元) | 雇员(人) | 人均收入(千美元) |
1975 | 16 | 3 | ? |
1976 | 22 | 7 | ? |
1977 | 382 | 9 | ? |
1978 | 1356 | 13 | ? |
1979 | 2390 | 28 | ? |
1980 | 8000 | 38 | ? |
…… | …… | …… | ? |
1995 | 5937000 | 17800 | ? |
下面的程序中,已经定义好了这些数据:
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,598027,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
编程,将data段中的数据按如下格式写入到table段中,并计算21年中的人均收入(取整),结果也按照下面的格式保存在table段中。
解析
本次实验最重要的就是如何定位存储在data中的原数据和table段中数据项的位置。
分别用ds和es保存data段和table段的段地址,将table看成结构型数据的数组,内包含多个数据项,可以用[si](si每次循环增加10h)寻址。
年份数据是字符串,每个年份占4个字节,用bx指向第一个字节,可以一个字节一个字节的mov,也可以一个字一个字的mov,一个年份数据移动结束,bx需要加4h。
总收入数据是双字型,占4个字节,可以用新的寄存器存储第一个字节的位置,一个数据移动结束,需要加4个字节,与年份数据一样,为了减少寄存器的使用,可以用bx+84指向该项的第一个字节。
雇员人数是字型数据,占2个字节,每次移动结束,需要增加2h,与上述两项不同,不能用同个寄存器,故用si指示该项。
人均收入=收入/雇员数,取整故只需要商。
此时一条记录已经成功写入,再进行21次循环即可。
代码
assume cs:codesg
data segment
db '1975','1976','1977','1978','1979','1980','1981','1982','1983','1984','1985','1986','1987','1988','1989','1990','1991','1992','1993','1994','1995'
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514,345980,598027,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,11542,14430,15257,17800
data ends
table segment
db 21 dup ('year summ ne ?? ')
table ends
codesg segment
start: mov ax,data
mov ds,ax
mov ax,table
mov es,ax
mov si,0a8h
mov di,0
mov dx,0
mov bx,0
mov cx,21
s: mov ax,ds:[bx]
mov es:[di+0h],ax
mov ax,ds:[bx+2h]
mov es:[di+2h],ax
mov ax,ds:[bx+54h]
mov es:[di+5h],ax
mov ax,ds:[bx+56h]
mov es:[di+7h],ax
mov ax,ds:[si]
mov es:[di+0ah],ax
mov ax,ds:[bx+54h]
mov dx,ds:[bx+56h]
div word ptr ds:[si]
mov es:[di+0dh],ax
add bx,4h
add si,2h
add di,10h
loop s
mov ax,4c00h
int 21h
codesg ends
end start
执行程序,查看内存检查,结果正确,如下所示。