• 汇编语言程序设计


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

    本文来自王爽著《汇编语言(第三版)》实验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])的操作和高级语言中的数组,结构体“太相似”了。因此要完成这个程序并不困难。

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

  • 相关阅读:
    152. 乘积最大子数组
    Java中wait和sleep方法的区别(美团面试面到了)
    HashMap1.7与1.8的区别
    类型转换
    Goland控制台中文乱码
    Spring 之 IOC
    Spring定时任务/Cron
    Mybatis 不加载xml文件
    MySQL :=和=的区别
    Go 第一个程序
  • 原文地址:https://www.cnblogs.com/wyf12138/p/6581530.html
Copyright © 2020-2023  润新知