gpt4 book ai didi

c# - 在 C++ 中托管 CLR 运行时

转载 作者:太空宇宙 更新时间:2023-11-03 16:22:21 25 4
gpt4 key购买 nike

我正在为一个允许在核心应用程序中托管 CLR 的项目进行扩展。有了这个,我计划允许这个扩展来管理它在自身内部加载/卸载的托管扩展。也就是说,我需要使用单独的 AppDomains 来确保卸载是可能的。

目前,我能够设置域并加载插件文件,但那时我被卡住了。我不确定如何随意调用域加载程序集中的函数等等。

这是我到目前为止的加载设置,减去错误检查等:

ICorRuntimeHost* lpRuntimeHost = NULL;
CorBindToRuntimeEx( L"v4.0.30319", L"wks", 0, CLSID_CorRuntimeHost, IID_PPV_ARGS( &lpRuntimeHost ) );

lpRuntimeHost->Start();

// File data read from disk.
// Dll file just CreateFile/ReadFile and insert into pluginFileData.
CComSafeArray<BYTE> pluginFileData;

IUnknown* lpUnknown = NULL;
lpRuntimeHost->CreateDomain( wstrPlugin.c_str(), NULL, &lpUnknown );

CComPtr<_AppDomain> appDomain = NULL;
lpUnknown->QueryInterface( &appDomain.p );

CComPtr<_Assembly> appAssembly = NULL;
hResult = appDomain->Load_3( pluginFileData, &appAssembly );

我有一个类库,所有插件都必须引用和使用它才能被视为插件。到目前为止,它只不过是一个要继承的基类:

namespace FrameworkAPI
{
public class IFrameworkPlugin
{
public override bool Initialize(IntPtr interfaceObj)
{
return false;
}
}
}

然后扩展将引用该类库并将其用作其基础:

namespace ClassLibrary1
{
public class Main : IFrameworkPlugin
{
public override bool Initialize(IntPtr interfaceObj)
{
// Return true to stay loaded.
return true;
}
}
}

我坚持的是如何做一些事情:

  • 如何获取主类但作为基类调用基类中允许主类仍然处理的方法?
  • 如何确保主类继承基类,从而确保它是一个有效的插件文件?
  • 我如何从 C++ 端自由调用方法来触发 C# 插件中的事件。

对于触发事件,C++ 插件在加载后会调用 C# 插件中的更多内容,例如渲染事件、命令处理等。

我在网上找到的大多数示例都特定于要求整个 C# 端是静态的,而我不希望这样。此外,大多数不使用单独的 AppDomain,而是全部在默认情况下执行。我不想要这个,因为它限制了卸载特定插件的能力。

如果有任何其他信息缺失或需要,请随时告诉我。

最佳答案

我通过为 C# 端使用 COM 公开接口(interface)解决了这个问题。

我已将 FrameworkAPI 放在一个单独的 DLL 中,并将它的主要接口(interface)暴露给 COM,然后在将使用它的插件中引用它。

在启用 COM 的情况下编译后,我可以导入生成的 .tlb 文件以轻松地在 C++ 中使用接口(interface)。

关于c# - 在 C++ 中托管 CLR 运行时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13518434/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com