了解平台目标



我在处理WPF应用程序中的非托管程序集时遇到问题。这是我的设置,归结为一个简单的草图:

X64 RUNTIME____________________
|                              |
| AS_EXEC (executing Assy, x86)|
|   |                          |
|   |                          |
|   AS_INT (interfaces, AnyCpu)|
|   |                          |
|   |                          |
|   AS_WRA_1 (wrapper, x86)    |
|   | |                        |
|   | AS_UNM_1 (unmanaged, x86)|
|   |                          |
|   AS_WRA_2 (wrapper, x64)    |
|   | |                        |
|   | AS_UNM_2 (unmanaged, x64)|
|   |                          |
|   AS_WRA_3 (wrapper, x86)    |
|     |                        |
|     AS_UNM_3 (unmanaged, x86)|
|______________________________|

我想做的是测试AS_WRA_1

  • 由于AS_WRA_1引用了仅在X86中工作的非托管代码,我认为最好将此项目设置为X86本身,以防止使用会导致BadImageFormat异常。

  • AS_INT包含用于所有AS_WRA实现的接口,并且被设置为ANY CPU

  • 我在64位运行时,所以我还将AS_EXEC设置为X86

  • AS_WRA_2只能在64位中工作,AS_WRA_3只能在32位中工作(这意味着基本上我不能同时运行它们,但由于我只想测试AS_WRA_1,我或多或少地很高兴地忽略了这一点——欢迎回来,DLL地狱!)。

在运行时,我使用反射从用户在UI中选择的包装器创建一个实例。奇怪的是,结果如下:

  • 我可以从AS_WRA_2创建实例
  • 我得到了AS_WRA_1AS_WRA_3的BadImageFormatExceptions

这与我的预期完全相反。。。我在这里做错了什么?

如果您有一个用x86(Assy)编译的可执行文件,它将始终在x86中运行,并且它的所有依赖项都必须在x86或AnyCpu中(它们也将在x86中执行)。

您不能让可执行文件同时执行x86和x64中的非托管资源,因此您将无法从Assy访问AS_UNM_1和AS_UNM_2,因为AS_UNM_3是x64,Assy是x86。当Assy调用As_INT时,它也变成了x86。

相关内容

最新更新