Omega. 发表于 2022-5-29 18:33:07

关于 段地址 的问题





如上图例题,数据段里只有八个字节,ds=0b2dh, 那么程序为什么是从 0b3dh 开始?

debug里为什么cs=0b3e?

第二张图下面的分析没看懂。。。怎么data段的地址又变成了 0b3dh ?

一团乱。

jackz007 发表于 2022-5-29 19:23:24

       段地址的基本单位是 1,也就是说,是 16 个字节,在本例中,程序中的第一个段是 data,其中定义了 8 个字节的数据,占用了 8 个字节空间,在程序编译的时候,编译程序会为 data 分配最小的段空间 10h,code 段从下一个段空间开始,也就是从 data + 1 的段开始,程序加载时,程序起始段(ds)地址是 0B3D,那么,代码段(cs) 地址自然就是 0B3E。

Omega. 发表于 2022-5-29 21:20:18

本帖最后由 Omega. 于 2022-5-29 21:28 编辑

jackz007 发表于 2022-5-29 19:23
段地址的基本单位是 1,也就是说,是 16 个字节,在本例中,程序中的第一个段是 data,其中定义了 8 ...

我也是这么想的,可图里debug显示ds是 0b2d, 不是0b3d

jackz007 发表于 2022-5-29 21:31:49

本帖最后由 jackz007 于 2022-5-29 22:26 编辑

Omega. 发表于 2022-5-29 21:20
我也是这么想的,可debug显示ds是 0b2d, 不是0b3d

   那是因为在程序入口的地方,还没有把 data 的段地址赋值给 ds 寄存器,不过,只要用 cs 段址减1就一定是data 段(ds)段的地址,不信,你可以试试。看看那两个字符串的位置是不是在段地址为 cs 减1,偏移地址为 0 开始的地方。

Omega. 发表于 2022-5-30 00:52:36

jackz007 发表于 2022-5-29 21:31
那是因为在程序入口的地方,还没有把 data 的段地址赋值给 ds 寄存器,不过,只要用 cs 段址减1就 ...

好的谢谢!
页: [1]
查看完整版本: 关于 段地址 的问题