寻址方式在结构化数据访问中的应用
power idea公司从1975年成立一直到1995年的基本情况如下:
下面的程序中,已经定义好了这些数据:
assume cs:code
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
编程,将data段中的数据按如下格式写入到table段中,并计算21年中的人均收入(取整),结果也按照下面的格式保存在table段中。

code:
assume cs:code ds:data es:table
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
code segment
start:
mov ax, data
mov ds, ax
mov ax, table
mov es, ax
mov bx, 0
mov di, 0
mov si, 0
;初始化数据
mov cx, 21 ;控制循环21次
s:
mov al, ds:[bx] ;写入年份
mov es:[di], al
mov al, ds:[bx+1]
mov es:[di+1], al
mov al, ds:[bx+2]
mov es:[di+2], al
mov al, ds:[bx+3]
mov es:[di+3], al
mov dx, 0a8h[si] ;写入公司雇员人数
mov es:0ah[di], dx
mov ax, 54h[bx] ;写入公司总收入
mov dx, 56h[bx] ;后面计算公司的收入,可以把被除数保留在ax和dx寄存器中
mov es:5h[di], ax ;方便后面做除法运算
mov es:7h[di], dx
div word ptr es:0ah[di] ;从地址中读取出除数的值
mov es:0dh[di], ax ;将除法得到的值ax放入对应的位置
add bx, 4
add si, 2
add di, 16
loop s
mov ax, 4c00h
int 21h
code ends
end start
寻址方式与数据访问
本文探讨了寻址方式在结构化数据访问中的应用,通过具体案例分析了poweridea公司从1975年至1995年间的数据,包括年份、公司总收入及雇员人数等,展示了如何利用寻址方式高效地读取和处理这些数据。

被折叠的 条评论
为什么被折叠?



