.NET程序集和DLL rebasing

Bri*_*sen 11 .net assemblies base-address rebasing

根据这篇文章,由于代码的JIT编译,.NET程序集不需要变基.文章指出:

"JIT编译的代码没有重定位问题,因为地址是在运行时根据代码放置在内存中的位置生成的.此外,MSIL很少受到基地址丢失的影响,因为MSIL引用是基于令牌的,而不是地址因此,当使用JIT编译器时,系统对基地址冲突具有弹性."

但是,我注意到VS2008为所有程序集分配了默认的0x0400000基址(项目属性>构建>高级),如果我listdlls /r为我的进程执行了一个操作,那么我的所有.NET程序集实际上都是默认的.

如果我自己分配地址,则不会进行变基.

我的问题是:在这种情况下,什么是重新定义的?为什么?

编辑:我应该补充一点,我不是在谈论NGen'ed集会.

lig*_*t78 3

CLR 加载机制在幕后使用 LoadLibrary,因此您会看到以下情况:无法在同一地址加载 2 个程序集。现在,当人们尝试对 dll 进行 rebase 时,通常的意思是避免出现性能问题。修复的命中,例如绝对地址和函数调用需要使用加载的基地址“重新定位”。CLR 没有这个问题(不确定应用程序中的静态数据,这是这些修复的第二部分,我需要阅读这一点),因为 MSIL 代码是在调用函数时按需加载的在托管代码中。然后 MSIL 被 jitted 并放置在堆上,我认为这与普通对象堆不同,就像 CLR 在应用程序中分配和布置新对象的方式一样。