汇编语言第四版(王爽)实验7

实验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

执行程序,查看内存检查,结果正确,如下所示。

结果

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值