关于 段地址 的问题
如上图例题,数据段里只有八个字节,ds=0b2dh, 那么程序为什么是从 0b3dh 开始?
debug里为什么cs=0b3e?
第二张图下面的分析没看懂。。。怎么data段的地址又变成了 0b3dh ?
一团乱。 段地址的基本单位是 1,也就是说,是 16 个字节,在本例中,程序中的第一个段是 data,其中定义了 8 个字节的数据,占用了 8 个字节空间,在程序编译的时候,编译程序会为 data 分配最小的段空间 10h,code 段从下一个段空间开始,也就是从 data + 1 的段开始,程序加载时,程序起始段(ds)地址是 0B3D,那么,代码段(cs) 地址自然就是 0B3E。 本帖最后由 Omega. 于 2022-5-29 21:28 编辑
jackz007 发表于 2022-5-29 19:23
段地址的基本单位是 1,也就是说,是 16 个字节,在本例中,程序中的第一个段是 data,其中定义了 8 ...
我也是这么想的,可图里debug显示ds是 0b2d, 不是0b3d 本帖最后由 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 开始的地方。 jackz007 发表于 2022-5-29 21:31
那是因为在程序入口的地方,还没有把 data 的段地址赋值给 ds 寄存器,不过,只要用 cs 段址减1就 ...
好的谢谢!
页:
[1]