1.将下面的程序编译连接,用Debug加载、跟踪,然后回答问题。
assume cs:code,ds:data,ss:stack
data segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
data ends
stack segment
dw 0,0,0,0,0,0,0,0
stack ends
code segment
start: mov ax,stack
mov ss,ax
mov sp,16
mov ax,data
mov ds,ax
push ds:[0]
push ds:[2]
pop ds:[2]
pop ds:[0]
mov ax,4c00h
int 21h
code ends
end start
①CPU执行程序,程序返回前,data段中的数据 不变 。
②CPU执行程序,程序返回前,CS=076C,SS=076B,DS=076A 。
③设程序加载后,CODE段的段地址为X,则DATA段的段地址为 X-2 ,STACK段的段地址为 X-1 。
(1)对比程序执行后data段的数据和执行前的数据,发现数据不变。因为先执行出栈操作两次,再执行入栈操作两次,两次的顺序相反,正好将先出栈的数据后进栈,后出栈的数据先进栈。所以data中的数据没有发生变化。
(2)通过执行后的结果可知cs=076C,ss=076B,ds=076A
(3)通过第二小问的结构可推断出 DATA段的段地址为 X-2 ,STACK段的段地址为 X-1 。
2.对要求的程序进行编译,连接,用debug加载,跟踪,然后回答问题。
(1)在程序返回前,我们用d命令查找data数据 发现其中的值并没有发生改变
(2)在程序返回前我们可以发现,cs=076C ,ss=076B,ds=076A
(3)该程序加载后,code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1
(4)对于如下定义的段:
name segment
...
name ends
如果段中的数据占N个字节,那么程序加载之后,该段的实际占有的空间为(N/16+1)*16。因为我们在分配空间时使用16个字节为单位的,所以不足16的时候仍然是分配16个字节来使用。
3. 对要求的程序进行编译,连接,用debug加载,跟踪,然后回答问题。
(1)对比程序执行后data段的数据和执行前的数据,发现数据不变。因为先执行出栈操作两次,再执行入栈操作两次,两次的顺序相反,正好将先出栈的数据后进栈,后出栈的数据先进栈。所以data中的数据没有发生变化。
(2)通过执行后的结果可知cs=076A,ss=076E,ds=076D
(3)通过第二小问的结构可推断出 DATA段的段地址为 X+3 ,STACK段的段地址为 X+4 。
4.如果将(1)、(2)、(3)题中的最后一条伪指令“end start”改为“end”(也就是说,不指明程序的入口),则哪个程序仍然可以正确执行?请说明原因。
答:第三条程序仍然可以正确执行,如果不指明入口位置,则程序从所分配的空间开始执行,前2个是数据段,只有从第3条开始是指令代码。1,2题是将数据段写在前面,但是3题是将数据段写在后面,将指令代码写在前面。所以,第三条程序仍然可以正确执行。
5.程序如下,编写code段中代码,将a段和b段中的数据依次相加,将结果存到C段中。
执行所有的代码后查看c段的值。
6.程序如下,编写code段中代码,用PUSH指令将A段中的前8个字型数据,逆序存储到B段中。
得到结果。
总结:这次实验做的不顺利,尤其是第5,6个实验。此次实验让我更加了解了段地址以及各种语言的运用,收获很大。