实验七
assume cs:code ,ds:data, es:tabledatasegment
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 349580,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,15257,17800
;以上表示21年公司雇员人数的21个word型数据
data ends
table segment
db 21 dup ('year summ ne ?? ')
table ends
code 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 ,
mov es: ,al
mov al ,
mov es: ,al
mov al ,
mov es: ,al
mov al ,
mov es: ,al
;以上8句用于存放年份
mov ax ,54H
mov dx ,56H
mov es:5H,ax
mov es:7H,dx
;以上4句用于存放总收入
mov ax ,0A8H
mov es:0AH,ax
;以上2句用于存放雇员数
mov ax ,54H
mov dx ,56H;用于初始化被除数
div word ptr ds:0A8H;除以人数
mov es:0DH,ax ;指定商存放的位置
;为下一循环做准备
add bx , 4 ;bx确定年份和收入
add si ,2 ;确定人数
add di ,16 ;di 确定的是每行的列数
loop s
mov ax ,4c00H
int 21H
code ends
end start
为何用P命令一次搞定所有循环,或直接用g命令运行至mov ax,4c00h,时再用D命令查看ES中的数据,发现程序似乎只运行到到1979年一行,后面的都没有做?而且1975年那一行也有点不对劲,把1975写成1e75,这到底是怎么回事啊?
看起来很厉害的样子 把程序的两个mov dx ,56H
改为 mov dx,56H 就OK了 vkevke_3437 发表于 2014-6-25 15:22 static/image/common/back.gif
把程序的两个mov dx ,56H
改为 mov dx,56H 就OK了
{:7_155:}谢谢,果然如此,但原因是什么呢? 风神翼龙 发表于 2014-6-26 20:47 static/image/common/back.gif
谢谢,果然如此,但原因是什么呢?
原因是每次循环之后DI的值可是加16的 而不是加4的
收入dd定义的是4个字节...如果用16 定位下一个收入 就跑到4*4后去了... 用这样的方法推入的数据会不会被后面的数给覆盖?感觉这个公司的总收入字符长度完全不够啊。
页:
[1]