实验五 编写、调试具有多个段的程序

代码一:

用r命令查看可知stack的段地址为076B,由源代码可知stack内有8字,即16字节。

通过DS=075A可知程序从076A开始存放,所以data区短地址是076A,刚好数据区也是16个字节。

(1)用d命令查看data段中的数据为:

(2)用g命令执行该代码:

可知cs=076C,ss=076B,ds=076A。

(3)设程序加载后,code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1。

代码二:

 

(1)data段中数据区域为076A:0    3,数据如上图。

(2)用g命令执行后,可知cs=076C,ss=076B,ds=076A,如下图:

(3)设程序加载后,code段的段地址为X,则data段的段地址为X-2,stack段的段地址为X-1.

(4)此处data的数据区间没有达到16个字节,但分配了16个字节。所以程序加载后分配空间是以16个字节为单位的,也就是说如果不足16个字节的也分配16个字节。那么段中数据占N个字节,则程序加载后,该段实际占有的空间为 (N/16+1)*16 。

当N被16整除时: 占有的空间为(N/16)*16。

当N不被16整除时: 占有的空间为(N/16+1)*16,N/16取最小正整数,还有一个余数,余数肯定小于16,加上一个1,再乘16字节。

代码三:

(1)由上图,data段中数据为23 01 56 04。

(2)g命令执行代码3.exe,cs=076A,ss=076E,ds=076D。

(3)设程序加载后,code段的段地址为X,则data段的段地址为X+3,stack段的段地址为X+4。

四:将1、2、3中最后最后一条伪指令“end start”改为“end”(也就是说,不指明程序的入口),会怎么样?

经过编译连接后发现,1和2不能正确执行,只有三可以正确执行。

这是因为当没有指明程序入口时,end指令从当前的cs:ip值开始进入程序。而在代码3以代码段开始,不会将其他数据段当成代码段执行,用r命令查看IP=0,所以能正确执行。

由实验可知如果不指明入口位置,则程序从所分配的空间开始执行。

代码五:

代码六:

实验总结:

   本章内容较少,但实验中涉及到的内容较多,发现自己在栈的这方面还是欠缺很多。

原文地址:https://www.cnblogs.com/ljzww/p/10016166.html