自写的汇编程序

     哈哈,今个儿真高兴呀!

    自学汇编两个多星期,昨天遇到了第八章 数据处理的两个基本问题 中的 实验七  寻址方式在结构化数据访问中的应用(学习汇编以来最复杂的程序)。好不容易将程序写了出来,敲到电脑上,一运行老是系统报错“数据溢出”,苦思近两天,今晚上突然有点灵感,又上机调试一下,谁知竟通过了。从网上下载王爽老师《汇编语言》的答案,一看,程序不一样,可结果一样,高兴呀!

    现在特地将自己编的程序挂到博客上,还请各位高手多多指点!同时也给自己及所有正在研究学习汇编的朋友鼓鼓劲!

 

以下是我自己写的程序:

 

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'

          dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514
          dd 345980,590827,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
          dw 11542,14430,15257,17800
data ends

 

table segment
          db 21 dup ('year summ ne ?? ')
table ends

 

codesg segment

  start:mov ax,data
           mov es,ax
           mov ax,table
           mov ds,ax

           mov bx,0
           mov si,0
           mov di,0

           mov cx,21

        s:mov ax,es:[0+si]
           mov ds:[bx+0],ax
           mov ax,es:[2+si]
           mov ds:[bx+2],ax

           mov ax,es:[84+si]
           mov ds:[bx+5],ax
           mov ax,es:[86+si]
           mov ds:[bx+7],ax
       
           mov ax,es:[168+di]
           mov ds:[bx+0ah],ax

           add si,4
           add di,2
           add bx,0010h

           loop s

           mov bx,0

           mov cx,21

      s0:mov ax,[bx+5]
           mov dx,[bx+7]
           div word ptr ds:[bx+0ah]
           mov ds:[bx+0dh],ax

           add bx,0010h

           loop s0

           mov ax,4c00h
           int 21h

codesg ends
end start


 

以下是我在网上搜到的此题答案:

 

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'

        ;以上是表示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

        ;以上是表示21年公司总收的21个dword型数据

 

        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 bx,0

        mov si,0

        mov di,0

        mov cx,21

 

        s:   ;进入循环

                mov al,[bx]

                mov es:[di],al

                mov al,[bx+1]

                mov es:[di+1],al

                mov al,[bx+2]

                mov es:[di+2],al

                mov al,[bx+3]

                mov es:[di+3],al

                ;以上8句的作用是存放年份

 

                mov ax,54h[bx]     ;第一个'年收入'的段基址为54H

                mov dx,56h[bx]

                mov es:5h[di],ax

                mov es:7h[di],dx

                ;以上4句的作用是存放公司总收入

 

                mov ax,0A8h[si]    ;第一个'人数'的段基址为0A8H

                mov es:0Ah[di],ax

                ;以上2句是存放公司的人数

 

                mov ax,54h[bx]

                div word ptr ds:0A8h[si]

                mov es:0dh[di],ax

                ;以上3句是存放人均收入

 

                add bx,4

                add si,2

                add di,16

                ;以上3句是为下一次循环时存放数据做准备

                ;3个寄存器递增的速度决定了所要存取的数据的位置的偏移地址

        loop s  ;跳到标号s处

 

mov ax,4c00h

int 21h

 

codesg ends

end start

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值