|
发表于 2018-9-7 08:27:59
|
显示全部楼层
解法一:
assume cs:code
a segment
db 1, 2, 3, 4, 5, 6, 7, 8 ;即使a段不满16字节,也占用0-f内存空间。
a ends
b segment
db 1, 2, 3, 4, 5, 6, 7, 8 ;即使b段不满16字节,也占用10-1f内存空间。
b ends
k segment
db 0, 0, 0, 0, 0, 0, 0, 0 ;即使k段不满16字节,也占用20-2f内存空间。
k ends
code segment
start: mov ax,a
mov ds,ax ;将a段关联ds段。则使用偏移地址即可得到b、k段数据。
mov bx,0h ;编译器默认十进制。
mov cx,8
s: mov ax,0h
add al,[bx]
add al,[bx+10h] ;b段在a段基础上偏移10H。
mov [bx+20h],al ;k段在a段基础上偏移20H。
inc bx
loop s
mov ax, 4c00H
int 21H
code ends
end start ;代码33行。
解法二:
assume cs:code
a segment
db 1, 2, 3, 4, 5, 6, 7, 8 ;即使a段不满16字节,也占用0-f内存空间。
a ends
b segment
db 1, 2, 3, 4, 5, 6, 7, 8 ;即使b段不满16字节,也占用10-1f内存空间。
b ends
k segment
db 0, 0, 0, 0, 0, 0, 0, 0 ;即使k段不满16字节,也占用20-2f内存空间。
k ends
code segment
start:mov ax,a
mov ss,ax ;将a段关联ss段。
mov ax,b
mov es,ax ;将b段关联es段。
mov ax,k
mov ds,ax ;将k段关联ds段。因为要将结果存到k段中,
;所以k段关联ds段代码看起来更清爽。
mov bx,0
mov cx,8
s:mov al,ss:[bx] ;将a段数据赋予al中。
add al,es:[bx] ;将b段数据相加至al中
mov [bx],al ;将a、b段数据相加结果赋予k段中。
inc bx
loop s
mov ax,4c00h
int 21h
code ends
end start ;代码36行。
|
|