Re: 关于书中程序地址的问题

《软件调试》的示例程序

关于书中程序地址的问题


wsbd008 2010-06-01, 00:27 上午
我在调试书中示例代码的时候,如果书中的地址是0012****,那么我机器中的地址就是0013****,后面的****是一样的,刚开始没在在意,好像就是12变成13了吧,我从后往前看的,现在在看81页的HiInt3程序时候,书中地址和我试验的地址一模一样,这是为什么啊?为什么会有时候一样,有时候不一样?程序的内存空间不是系统在4G的空间里面动态创建的吗?而且还有虚拟内存,页机制,为什么每次都会一样啊?

Re: 关于书中程序地址的问题


skyworth 2010-06-20, 08:52 上午
加载基址不一样而已

Re: 关于书中程序地址的问题


格蠹老雷 2010-06-20, 21:51 下午

在编译时,可以在链接选项中为每个模块指定加载地址(Output > Base Address),这个地址会被保存到模块的PE文件头结构中。运行时,进程加载器(Loader)会根据进程空间的实际情况和模块中的基地址信息来选择合适的加载位置。

如果模块中登记的基地址位置没有被占用,可以容纳下这个模块,而且当前进程没有启用ASLR(Address space layout randomization),那么加载器便会把这个模块加载到这个地址。如果占用了,那么只好找别的地方。如果启用了ASLR,那么加载器会努力让每次加载的位置不一样,目的是增强安全性。

如此看来,对于同一个程序,同一个模块可能加载到相同的位置,也可能加载到不同的位置,都是很正常的.

Powered by Community Server Powered by CnForums.Net