机制介绍
有些时候主程序是通过C/C++实现的,但是我们希望通过托管代码来扩展非托管程序,从而也获得托管代码带来的一系列优点。比如开发效率高,自动垃圾回收等。
运行托管与非托管代码根本区别在于托管代码是进程首先加载CLR然后通过CLR运行托管程序,而非托管代码则是操作系统直接根据其PE Header加载程序分配内存从而运行。因此如果需要通过托管代码来扩展非托管程序,首先要加载CLR来使非托管程序获得运行托管代码的能力。
- 调用 CLRCreateInstance 函数以获取 ICLRMetaHost 或 ICLRMetaHostPolicy 接口。 CLRCreateInstance 函数取代 .NET Framework 1.1 和 2.0 承载全局静态函数部分中列出的所有 CorBindTo* 函数。
- 调用 ICLRMetaHost::EnumerateInstalledRuntimes、ICLRMetaHost::GetRuntime 或 ICLRMetaHostPolicy::GetRequestedRuntime 方法以获取有效的 ICLRRuntimeInfo 指针。
- 调用 ICLRRuntimeInfo::GetInterface 方法。 为 rclsid 参数指定 CLSID_CLRRuntimeHost,并为 riid 参数指定 IID_ICLRRuntimeHost。
- 通过调用 ICLRRuntimeHost::Start 方法来启动运行时。
- 执行托管代码。
- 获取指向 ICLRControl 接

本文介绍了如何在C++程序中手动加载CLR运行托管代码,以扩展非托管程序的功能。通过调用CLRCreateInstance、ICLRRuntimeInfo::GetInterface等接口,启动运行时并执行托管代码。示例代码展示了如何执行一个静态方法Test,输出'Hello World!'。
最低0.47元/天 解锁文章
1862

被折叠的 条评论
为什么被折叠?



