我需要重新设置我用我的程序安装的DLL文件组,因为它是一个32位程序,地址空间现在太碎片了.还有一个问题是,由于基地址与某些DLL冲突,整个DLL在冷启动时被请求分页到RAM中,因此加载器可以对它们进行重新绑定.有些DLL是我们编译过的;其他人来自第三方.
我想要做的是有一个工具rebase给定一组DLL,以便DLL组占用一个连续的内存块.然后,在编译安装程序之前运行此工具,并将重新定义的DLL安装在应用程序的专用目录中.
据我所知,Windows SDK附带的REBASE.EXE工具确实做到了.给它一些DLL,然后重新定义它们.
不幸的是… Windows Software Development Kit (SDK) for Windows 8 Consumer Preview说:
Tools Many obsolete or deprecated tools have been removed from the Windows SDK. The following tools have been removed:
<snip> ReBase.exe
现在怎么办?我不想开始使用明显过时的工具,并且将在下一版本的Windows中消失.假设我正在读这个,那么使用ReBase.exe有什么替代品?我想限制自己使用Windows SDK和/或Visual Studio附带的工具,而不是引入第三方工具和/或编写我自己的rebase代码.
或者,我是否以错误的方式处理整个问题?
editbin.exe附带VS2010并具有/ REBASE选项.
C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC>editbin Microsoft (R) COFF/PE Editor Version 10.00.40219.01 Copyright (C) Microsoft Corporation. All rights reserved. usage: EDITBIN [options] [files] options: /ALLOWBIND[:NO] /ALLOWISOLATION[:NO] /BIND[:PATH=path] /DYNAMICBASE[:NO] /ERRORREPORT:{NONE|PROMPT|QUEUE|SEND} /HEAP:reserve[,commit] /LARGEADDRESSAWARE[:NO] /NOlogo /NXCOMPAT[:NO] /REBASE[:[BASE=address][,BASEFILE][,DOWN]] /RELEASE /SECTION:name[=newname][,[[!]{CDEIKOMPRSUW}][A{1248PTSX}]] /STACK:reserve[,commit] /SUBSYSTEM:{BOOT_APPLICATION|CONSOLE|EFI_APPLICATION| EFI_BOOT_SERVICE_DRIVER|EFI_ROM|EFI_RUNTIME_DRIVER| NATIVE|POSIX|WINDOWS|WINDOWSCE}[,#[.##]] /SWAPRUN:{[!]CD|[!]NET} /TSAWARE[:NO] /VERSION:#[.#]
正如Mark指出你要关闭ASLR,你可以通过使用/ DYNAMICBASE来做:否