我有一个小的32位进程,我正在win7 x64上调试,我看到它加载了"C:\windows\sysWow64\ntdll.dll“,但也加载了"C:\windows\system32\ntdll.dll”。
我知道x64模块和x86模块不能混合,但它们在这里...混合...
怎么会这样呢?
发布于 2012-04-17 23:45:16
这是WOW64的一个特殊“特性”,请参阅MSDN上的this article。相关的部分是:
WOW64模拟器在用户模式下运行。它提供了32位版本的Ntdll.dll和处理器内核之间的接口,并拦截内核调用。WOW64仿真器由以下DLL组成:
这些DLL以及64位版本的Ntdll.dll是唯一可以加载到32位进程中的64位二进制文件。
https://stackoverflow.com/questions/10194371
复制相似问题