将std::字符串从C++DLL返回到C#程序-&>指定给RtlFreeHeap的地址无效

Returning a std::string from a C++ DLL to a c# program -gt; Invalid Address specified to RtlFreeHeap(将std::字符串从C++DLL返回到C#程序-指定给RtlFreeHeap的地址无效)

本文介绍了将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的地址无效的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:将std::字符串从C++DLL返回到C#程序-&>指定给RtlFreeHeap的地址无效

基础教程推荐