汇编语言 - 第8章 数据处理的两个基本问题
本帖最后由 SВ 于 2019-10-14 12:06 编辑处理数据的两个基本问题,数据的首地址在哪里,数据的编码是什么(编码包含数据的长度信息)。
在第8章中,难点是内存寻址的方式,其中偏移地址或者称为有效地址EA
是根据下面的intel 指令编码表的后面部分来的:
上图加上默认段寄存器前缀的完整格式:
更多内容可以回顾:https://fishc.com.cn/forum.php?mod=viewthread&tid=147146&ctid=1572 本帖最后由 SВ 于 2019-10-15 08:41 编辑
我们来解释一下实验7的答案,这个答案采用一个循环的方案。
assume cs:code,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'
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 11452,14430,15257,17800
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 ax,
mov es:,ax
mov ax,.2
mov es:.2,ax
mov ax,.84
mov es:.5,ax
mov dx,.86
mov es:.7,dx
div word ptr ds:.168
mov es:.13,ax
mov ax,.168
mov es:.10,ax
add di,2
add bx,4
add si,16
loop s
mov ax,4c00h
int 21h
code ends
end start 本帖最后由 SВ 于 2019-10-14 14:41 编辑
start:
mov ax,data
mov ds,ax
执行完上面的代码,ds指向data数据段
本帖最后由 SВ 于 2019-10-14 15:07 编辑
接着:
mov ax,table
mov es,ax
执行完上面的代码,es指向table数据段
逻辑地址 0757:00E0 与 逻辑地址 ES:0 即 0765:0 等价
本帖最后由 SВ 于 2019-10-15 08:42 编辑
;接下来,
;因为有两种自增长度,所以需要bx和di两个参数来指向源数据,一个参数无法完成对源数据的操作。
;bx表示当前需要操作的源数据的元素,以双字节为单位自增
mov bx,0
;si表示目的数据段 table数据段的每一列的索引
mov si,0
;di表示当前需要操作的源数据的元素,以单字节为单位自增
mov di,0
;一共21行,循环21次
mov cx,21
;以下是每一行需要进行的操作
;搬运年份数据,每次搬运2个字节
s:mov ax,
mov es:,ax
mov ax,.2
mov es:.2,ax
;搬运收入数据,每次搬运2个字节
mov ax,.84
mov es:.5,ax
mov dx,.86
mov es:.7,dx
;计算并填入人均收入
div word ptr ds:.168
mov es:.13,ax
;搬运雇员数数据
mov ax,.168
mov es:.10,ax
;操作完一行,各个参数自增
add di,2
add bx,4
add si,16
loop s
页:
[1]