|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
assume ds:datasg cs:codesg es:tablesg
datasg segment
db '1975','1976','1977','1978','1979','1980','1981','1982','1983','1984','1985','1986','1987'
'1988','1989','1990','1991','1992','1993','1994','1995'
;21个字符串定义年份,范围21*4转H为0~54H
dd 16,22,382,1356,2390,8000,16000,24486,50065,97479,140417,197514,345980,590827,803530,1183000,2759000,
2759000, 3753000,4649000,5937000;以上为公司21年的收入,范围21*4转为H为54H~018H 在做这个双字数据定义的时候,编译器是不是自动将十进制转换为十六进制?
;还是说,没有必要转换进制,编译器自动分配入字的高低位?
dw 3,7,9,13,28,38,130,220,476,778,1001,1442,2258,2793,4037,5635,8226,11542,14430,15257,17800
;以上为公司21年雇员人数,范围018H~0132H
datasg ends
tablesg segment
db 21 dup('year summ ne ?? ') ;范围0132H~0280H
tablesg ends
codesg segment
start mov ax,datasg
mov ds,ax
mov ax,tablesg
mov es,ax
mov bx,0
mov si,0
mov di,0
mov cx,21 ;是不是不加H,编译器默认十进制,加H默认十六进制?
s mov ax,ds:[bx] ;将年份分成两个字,作为高低位用DX表示高位,AX表示低位,复制给table段中的‘year'四个字节
mov dx,ds:[bx+2]
mov es:[di],ax
mov es:[di+2],dx
add bx,4h
add di,10h
loop s
mov cx,21 ;因为上面已经把CX减到0了,这里感觉用push和pop,和直接重新赋值没有多大区别,直接赋值好像代码还少一行
mov dx,0
mov di,5
mov bx,54h
s0 mov ax,ds:[bx] ;将收入双字看做是四个字节的结构,用两个十六位的寄存器转存到table段中,思路和年份的思路一样
mov dx,ds:[bx+2]
mov es:[di],ax
mov es:[di+2],dx
add bx,4
add di,10h
loop s0
mov bx,018h ;重新赋值将要用到的参数重新赋值
mov cx,21
mov di,11
s1 mov ax,ds:[bx] ;将雇员人数的字结构做处理,转存到table段中
mov es:[di],ax
add bx,2h
add di,10h
loop s1
mov si,018h ;si做为除数所在的寄存器
mov bx,54h
mov cx,21
mov di,14 ;
s2 mov ax,ds:[bx] ;这两行定义了被除数的高低位
mov dx,ds:[bx+2]
div si
mov es:[di],ax
add si,2
add di,16
add bx,4
loop s2
mov ax,4c00h
int 21h
codesg ends
start end
|
|