本文介绍了将std::字符串从C++DLL返回到C#程序-&>指定给RtlFreeHeap的地址无效的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
在我的C++DLL的一个函数中,我向我的C#应用程序返回了一个std::字符串。它看起来很像这样:std::string g_DllName = "MyDLL";
extern "C" THUNDER_API const char* __stdcall GetDLLName()
{
return g_DllName.c_str();
}
但当我的C#代码调用此函数时,我在输出窗口中收到以下消息:
Invalid Address specified to RtlFreeHeap( 00150000, 0012D8D8 )
C#中的函数声明如下:
[DllImport("MyDll", EntryPoint = "GetDLLName")]
[return: MarshalAs(UnmanagedType.LPStr)]
public static extern string GetDLLName();
根据我在网上找到的信息,有时当使用的新版本(调试或发布等)与删除不一致时,会出现此消息。但我不确定我的情况是不是这样。所以我不确定到底是什么原因造成的。也许Mashalla夫妇可能与此有关?
有什么想法吗?
谢谢!
推荐答案
我设法找到了问题。这就是C#定义的方式。据我所知,将MarshallAs(UnManagedType.LPStr)与字符串返回类型结合使用可以使其在完成时尝试释放字符串。但是,因为字符串来自C++DLL,并且很可能是一个完全不同的内存管理器,所以它失败了。即使它没有失败,我也不想让它自由。
我找到的解决方案是将C#声明更改为(C++代码保持不变):
[DllImport("MyDll", EntryPoint = "GetDLLName")]
public static extern IntPtr GetDLLName();
这样它就只返回一个指向字符串数据的指针。然后要将其更改为字符串,请将其传递给Marshal.PtrToStringAnsi()
return Marshal.PtrToStringAnsi(GetDLLName());
,它被包装到另一个函数中以保持整洁。
我从这个页面找到了解决方案: http://discuss.fogcreek.com/dotnetquestions/default.asp?cmd=show&ixPost=1108
这篇关于将std::字符串从C++DLL返回到C#程序-&>指定给RtlFreeHeap的地址无效的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!