我遇到了一个奇怪的问题。我创建了一个 Windows 运行时组件(用于 Windows 应用商店),它通过一些 C# 包装类使一些遗留的 C/C++ 代码可用于 .NET。
我编写了一个引用 WRC项目(同一解决方案中的两个项目)的测试工具 Store App(以下称为“test1” )。它调用组件,一切正常。
接下来,我从 WRC 项目中获取以下输出文件:
MyWrtComponent.dll
MyWrtComponent.exp
MyWrtComponent.pdb
MyWrtComponent.pri
MyWrtComponent.winmd
...并尝试从另一个商店应用程序项目(“test2”)中使用它们。在这个项目中,我没有引用 MyWrtComponent 项目,而是添加了对 .winmd 文件的引用。一切正常,但是当我运行 test2 应用程序时,只要我尝试使用在 MyWrtComponent 中实现的 C# 类之一,就会从 mscorlib 获得 System.IO.FileNotFound 异常:
at System.StubHelpers.StubHelpers.GetWinRTFactoryObject(IntPtr pCPCMD)
at MyWrtComponent.MyWrtClass..ctor()
The specified module could not be found.
(Exception from HRESULT: 0x8007007E)
使用 MyWrtComponent 的发布与调试版本没有任何区别。
在 test2 上运行 ProcMon,我看到加载 vccorlib120_app.DLL(或 vccorlib120d_app.DLL,如果我正在构建调试)的几次失败尝试:
QueryOpen F:\test2\bin\Debug\AppX\vccorlib120d_app.DLL NAME NOT FOUND
QueryOpen F:\test2\bin\Debug\AppX\vccorlib120d_app.DLL NAME NOT FOUND
CreateFile C:\Windows\SysWOW64\vccorlib120d_app.DLL NAME NOT FOUND
我已确认此文件在我的 C:\Windows\SysWOW64 文件夹中不存在。我不知道这是否与我的问题有关。
当我运行 test1 时,会搜索不同的位置,并找到该文件:
QueryOpen F:\test1\bin\Debug\AppX\vccorlib120d_app.DLL NAME NOT FOUND
CreateFile C:\Program Files\WindowsApps\Microsoft.VCLibs.120.00.Debug_12.0.20827.3_x86__8wekyb3d8bbwe\vccorlib120d_app.dll SUCCESS
我比较了两个测试项目的 bin\Debug\AppxManifest.xml,发现了一个重要的区别;test1 有以下内容,而 test2 没有:
<Dependencies>
<PackageDependency Name="Microsoft.VCLibs.120.00.Debug" MinVersion="12.0.20827.3" />
</Dependencies>
如果我将这三行添加到 test2 的生成输出并运行应用程序,它可以工作,但当然这不是真正的修复。
有谁明白这里发生了什么?MyWrtComponent 是否具有某种无法通信的依赖项,或者我是否应该做一些事情来将 vccorlib120d_app.DLL 与我的运行时组件一起打包,或者...?
提前致谢。