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

注意数据一开始是怎么存放的,年份(字符串)是顺序存放,其他数据均是有按照高低位的规则存放,所以放入table中也相应地存放就好了(不用反过来),例:收入的第一个数据:16 : 10 00 00 00。

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'
	;以上表示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年公司总收入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
 
codesg segment
start:
	mov ax,data
	mov ds,ax

	mov ax,table
	mov ss,ax
;对表格中的每一列分别循环21次
;年份(4个字节:需要存2次,因为ax一次只能放2个字节)
	mov bx,0
	mov si,0
	mov cx,21
s0:
	mov ax,[si]
	mov ss:[bx],ax

	mov ax,[si+2] ;si并没有发生改变,所以下面的si要加4!
	mov ss:[bx+2],ax

	add bx,10h
	add si,4 ;si发生改变
	loop s0
;第一个循环结束后,si = 54h(64),类似C的循环,所以已经到了下一个数据(16)的开头
;一开始数据之间不需要空格,空格是在table中
;收入
	mov bx,5 
	mov cx,21
s1:
	mov ax,[si] ;不是mov ax,[si+2],注意一开始数据的存放方式
	mov ss:[bx],ax

	mov ax,[si+2]
	mov ss:[bx+2],ax

	add bx,10h
	add si,4
	loop s1
;雇员数
	mov bx,10
	mov cx,21
s2:
	mov ax,[si]
	mov ss:[bx],ax
	add bx,10h
	add si,2
	loop s2
;人均收入
	mov bp,0
	mov si,5
	mov cx,21
s3:
	mov dx,ss:[bp+si+2] ;高位放dx
	mov ax,ss:[bp+si]   ;低位放ax
	mov bx,ss:[bp+si+5] 
	div bx
	mov ss:[bp+si+8],ax
	add bp,10h
	loop s3
	
	mov ax,4c00h
	int 21h
	
codesg ends
end start

结果如下:(图中分别是年份、收入、雇员人数、人均收入) 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值