看王爽的《汇编语言》课后有一实验——“实验7 寻址方式在结构化数据访问中的应用”,硬是写不出来,在网上找了很多,有的结果出来的,也正确,可是代码风格上总感觉别扭,不是我想要的,也就是没找到自己觉得满意的答案。最后还是自己码出来了,结果正确,代码风格合适,母不嫌子丑,自我感觉挺好的,嘿嘿,毕竟花了不少时间码出来的。我贴出来是想得到更好的理解和更多的进步,希望理解。如果还有值得改进的地方,请师傅们斧正。
;实验7 寻址方式在结构化数据访问中的应用
;编程,将data段中的数据按如下格式写入到table段中,并计算21年中的人均收入(取整),结果也按照下面的格式保存在table段中。
assume cs:codesg, ds:data
data segment
;ds:0
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个字符串
;ds:54h
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型数据
;ds:0a8h
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430,45257,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 ax,table
mov es,ax
mov cx,21
mov bx,0
mov si,0
mov di,0
s:
mov ax,0[si][0]
mov es:[bx].0[0], ax ;year
mov ax,0[si][2]
mov es:[bx].0[2], ax ;year
mov ax,54h[si][0]
mov es:[bx].5[0], ax ;summ
mov ax,54h[si][2]
mov es:[bx].5[2], ax ;summ
mov ax,0a8h[di][0]
mov es:[bx].0ah[0], ax ;ne
mov ax,es:[bx].5[0] ;被除数的低位 2 byte
mov dx,es:[bx].5[2] ;被除数的高位 2 byte
div word ptr es:[bx].0ah[0];summ/ne取整数
mov es:[bx].0dh[0],ax ;??商,余数在dx中
add bx,10h
add si,4
add di,2
loop s
mov ax,4c00h
int 21h
codesg ends
end start
------解决方案--------------------
mov ax,a[di][0]
a db '1975','1976','1977','1978','1979','1980','1981','1982','1983'
------解决方案--------------------
你这样能汇编通过吗?