汇编语言程序设计

寻址方式在结构化数据访问中的应用

本文来自王爽著《汇编语言(第三版)》实验7

问题描述

power idea公司从1975年成立一直到1995年的基本情况如下:

年份收入(千美元)雇员(人)人均收入(千美元)
1975 16 3 ?
1976 22 7 ?
1977 382 9 ?
1995 5937000 17800 ?

编程,将data段中的数据按如下格式写入到table段中,并计算21年中的人均收入(取整),结果也按照下面的格式保存在table段中。

table段

编程思路

将data段的数据看作多个数组,table中的数据看作一个结构性数据的数组,每个结构型数据中包含多个数据项。
用bx定位每个结构型数据,立即数idata定位数据项,用si定位data段数组元素即可。要用到寄存器相对寻址[bx+idata]。

代码实现

assume  cs:codesg,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'
  ;偏移地址范围0-53h,表示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
  ;偏移地址范围54h-0a7h,表示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
  ;偏移地址范围0a8h-0d1h,表示21年公司雇员人数的21word型数据
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,0
        mov bx,0
        mov cx,21
        ;保存年份前两字节
    s0: mov ax,[si]
        mov es:[bx],ax
        ;保存年份后两字节
        mov ax,[si+2]
        mov es:[bx+2],ax
        add si,4

        add bx,10h
        loop s0
;---------------保存总收入-----------------------------
        mov si,54h
        mov bx,0
        mov cx,21
        ;保存总收入的前两字节
    s1: mov ax,[si]
        mov es:[bx+5],ax
        ;保存总收入的后两字节
        mov ax,[si+2]
        mov es:[bx+5+2],ax
        add si,4

        add bx,10h
        loop s1
;----------------保存雇员数------------------------------
        mov si,0a8h
        mov bx,0
        mov cx,21

    s2: mov ax,[si]
        mov es:[bx+0ah],ax
        add si,2

        add bx,10h
        loop s2
;-------------计算并保存人均收入-------------------------

        mov bx,0
        mov cx,21

    s3: mov ax,es:[bx+5]
        mov dx,es:[bx+5+2]
        div word ptr es:[bx+0ah]
        mov es:[bx+0dh],ax

        add bx,10h
        loop s3
;---------------------------------------------------------------        
        mov ax,4c00h
        int 21h

codesg  ends

end start

总结

这里的汇编程序就相当于C程序中给结构体数组赋值。汇编中的一些寻址方式(比如:[bx+idata],[bx+si],[bx+si+idata])的操作和高级语言中的数组,结构体“太相似”了。因此要完成这个程序并不困难。

另外,明天汇编语言程序设计这门课就要期末考试了,我平时不会在博客上贴上汇编的代码,今天就算个福利,把自己略显幼稚的汇编代码贴上,希望大家都能在考试中取得好成绩。

原文地址:https://www.cnblogs.com/wyf12138/p/6581530.html