windows – ASLR会导致Dlls加载缓慢吗?

在MSVC中,Base Address Randomizaiton是认选项.(自VS2005起?)

所以,我不再手动重新设置dll的基地址.

但是当我使用VS2003时,我重新调整了我的所有dll以提高加载性能.

如果我使用ASLR选项,加载性能总是会降低吗?
(我可以获得其他好处)

最简洁的答案是不.

在没有ASLR的系统(例如XP)上,在非首选地址加载DLL有几个成本:

>必须解析重定位部分,并且必须将修正应用于整个图像.
>应用fixups的行为会导致写入时写入错误,这些错误cpu方面相对昂贵,并且即使它们未被应用程序本身引用,也会强制从磁盘读取页面.
>将DLL加载到非首选地址的每个进程都会获取写入的每个页面的私有副本,从而导致内存使用量增加.

第2项和第3项是迄今为止最大的成本,也是之前手动重新定义DLL的主要原因.

使用ASLR,操作系统透明地应用修正,使其看起来像DLL实际上是在其首选地址加载的.没有写时复制错误,也没有创建进程私有页面.此外,修正仅应用于应用程序实际访问的页面,而不是整个图像,这意味着不会从磁盘读取额外的数据.

除此之外,手动重新定位方案无法阻止所有基地址冲突(例如,来自不同供应商的DLL可能会相互冲突,或者由于修补程序而导致操作系统DLL的大小增加并且溢出到保留的范围内一些其他DLL等). ASLR在处理这些问题时效率更高,因此在整体查看系统时,它实际上可以提高性能.

相关文章

Windows2012R2备用域控搭建 前置操作 域控主域控的主dns:自...
主域控角色迁移和夺取(转载) 转载自:http://yupeizhi.blo...
Windows2012R2 NTP时间同步 Windows2012R2里没有了internet时...
Windows注册表操作基础代码 Windows下对注册表进行操作使用的...
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的...
一个简单的Windows Socket可复用框架说起网络编程,无非是建...