(1)
①data段的数据在执行程序时,程序返回前并未改变
②程序返回前,CS=076C,SS=076B,DS=076A。
③由图中ss,ds,cs可知,若code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。
(2)
①由图可知,与(1)的结果一样,data段的数据在执行程序后,程序返回前仍未改变
②从图可知出,CPU执行程序,程序返回前,CS=076C,SS=076B,DS=076A。
③code段的段地址为X时,则data段的段地址为X-2,stack段的段地址为X-1。
④对比(1)(2)可以发现,(1)中data段数据有16个字节,占用了16个字节空间,而(2)中data段数据只有4个字节,但实际上(2)也占用了16字节的空间,其中不足的部分都用0补全了。所以推测,若段中数据为N个字节,则该段实际占用的空间为 ((N+15)/16)*16 个字节。
(3)
①data段的数据在执行程序后,程序返回前并未改变
②从图中可以看出,CPU执行程序,程序返回前,CS=076A,SS=076E,DS=076D。
③进一步可以发现,若code段的段地址为X,则data段的段地址为X+3,stack段的段地址为X+4。
(4)如果将最后一条伪指令“end start”改为“end”,相当于没有指明程序入口,此时程序就会从加载进内存的第一个单元起开始执行。在(1)(2)题中,都是数据先加载进内存,CPU会误把数据也当成指令执行,最终不能保证被正确执行;而(3)题则是代码段先被加载进内存,因而可以被正确执行。
(5)
源码
assume cs:code
a segment
db 1,2,3,4,5,6,7,8
a ends
b segment
db 1,2,3,4,5,6,7,8
b ends
c segment
db 8 dup(0)
c ends
code segment
start:
mov bx,0
mov dx,0
mov cx,8
s:mov dx,0
mov ax,a
mov ds,ax
add dl,[bx]
mov ax,b
mov ds,ax
add dl,[bx]
mov ax,c
mov ds,ax
mov [bx],dl
inc bx
loop s
mov ax,4c00h
int 21h
code ends
end start
使用t命令单步调试至mov [bx],dl命令 ,此时上一条命令mov ds,ax已经执行完毕,此时ds中保存的就是c段的段地址
查看此时未加载完毕前c段中内容
运行到程序返回前,此时的DS中保留的就是c段的段地址,查看c段中的数据;
(6)
源码
assume cs:code
a segment
dw 1,2,3,4,5,6,7,8,9,0ah,0bh,0ch,0dh,0eh,0fh,0ffh
a ends
b segment
dw 8 dup(0)
b ends
code segment
start:
mov ax,a
mov ds,ax
mov ax,b
mov ss,ax
mov sp,0fh
mov bx,0
mov cx,8
s:push [bx]
inc bx
inc bx
loop s
mov ax,4c00h
int 21h
code ends
end start