流风逸雪 发表于 2020-4-5 15:25:24

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

没法上图,至少table初始化很成功,除法div也通过编译,结果也正确:
assume cs:codesg,ss:stacksg
stacksg segment
dw 0,0,0,0,0,0,0,0
stacksg ends

datasg 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'
;年份(每一个元素占4个字节)

dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,19514
dd 345980,590827,803530,1183000,1843000,2759000,3753000,4649000,5937000
;总收入(每一个元素占4个字节)

dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226
dw 11542,14430,15257,17800
;雇员数(每一个元素占2个字节)
;而且都是紧挨着
datasg ends

table segment
db 21 dup ('year sumn ne ?? ');长16个字节

table ends

codesg segment
start:       
        ;table初始化部分
        mov ax,stacksg
        mov ss,ax
        mov sp,16
        mov ax,datasg;此处定位到datasg的year的位置,与table 的year相隔00e0H
        mov ds,ax
        mov bx,00e0H;bx作为tablesg的指针
        mov di,0;di作为datasg指针
        mov si,0

        mov cx,21
s:;这里其实可以不用嵌套循环但为了清晰指针跳动的过程于是就这样了
        push cx
        mov si,0
        mov cx,4
        s0:;遍历一行
                mov al,;year一个一个字节替换为年份
                mov ,al
                inc si
                inc di
                loop s0

        add bx,16;遍历完后跳到下一行

        pop cx
        loop s
       
       
        mov bx,00e0H;恢复table指针的位置到第一行第一位
        mov cx,21;其实完全可以与上一个循环合并但不会减少太多时间复杂度
s1:
        push cx
        mov si,0
        mov cx,4
        s2:
                mov al,;sumn一个一个字节替换为收入
                mov ,al
                inc si
                inc di
                loop s2

        add bx,16

        pop cx
        loop s1
       
        mov bx,00e0H
        mov cx,21
s3:
        mov si,0

        mov ax,;ne 一个一个字替换为雇员数
        mov ,ax
        add di,2

        add bx,16
       

        loop s3
       
       
        mov cx,21
        mov di,00e0H;这里将di替代bx作table指针作用
       
       
       
s5:;除法部分
        mov bx,;将ne赋给bx做除数
        mov ax,;将sumn低位赋给ax作被除数
        mov dx,;将sumn高位赋给dx作被除数
        div bx;使用div 来用sumn/ne替换??
        mov ,ax
        add di,16
       

        loop s5



        mov ax,4c00H
        int 21h
codesg ends
end start
页: [1]
查看完整版本: 实验7 寻址方式在结构化数据访问中的应用