我正在通过将 Mono 嵌入到我的 Windows 的 C++ 程序中来编写插件系统。现在我正在尝试向 C# 运行时公开一个 C++ 函数,以便脚本可以从主程序调用 C++ 函数。
这样做是这样的:
mono_add_internal_call("Hello::MonoMsg",MonoMsg);
我除了煮熟了两个例子的copypasta之外,都遇到了同样的错误:
C:\Projects\MonoTestBed\main.cpp|34|error: invalid conversion from 'void (*)(MonoString*)' to 'const void*'|
C:\Projects\MonoTestBed\main.cpp|34|error: initializing argument 2 of 'void mono_add_internal_call(const char*, const void*)'|
现在,我找到了一个人关于这个 /somewhere/ 的帖子,但我没有找到解决方案,只有一种让它编译的方法 - 将 MonoMsg 转换为 (void*)MonoMsg。这会让它编译,但是当你运行它时它会中断,崩溃 kerblam - 它会报告找不到该函数。
这是相关代码,包括以防万一。
#include <iostream>
#include <stdio.h>
#include <string>
#include<mono/jit/jit.h>
#include<mono/metadata/assembly.h>
#include <mono/metadata/mono-config.h>
#include <mono/metadata/mono-debug.h>
#include <mono/metadata/debug-helpers.h>
#include <mono/metadata/appdomain.h>
#include <mono/metadata/object.h>
#include <mono/metadata/threads.h>
#include <mono/metadata/environment.h>
#include <mono/metadata/mono-gc.h>
using namespace std;
__declspec(dllexport) void MonoMsg(MonoString *msg)
{
cout<<msg;
}
int main(int argc, char *argv)
{
// mono_set_dirs(NULL,NULL);
// mono_config_parse(NULL);
MonoDomain *domain = mono_jit_init("C:\\herro.exe");
MonoAssembly *assembly= mono_domain_assembly_open(domain,"C:\\herro.exe");
cout<<assembly;
//mono_jit_exec(domain,assembly,0,NULL);
mono_add_internal_call("Hello::MonoMsg",MonoMsg);
. . .
编辑:我差点忘了提到这是某种 erm P/invoke 方法?或者其他的东西。: