如何释放由C#编组分配给C ++的非托管内存

时间:2016-09-23 13:36:16

标签: c# c++ interop marshalling

C ++代码调用返回字符串的C#方法。我应该如何在C ++中释放分配的非托管内存?我应该使用free()还是删除?

C#:

[Guid("52E4971F-E075-41BA-A84F-B6BE8BD66A21")]
[InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
[ComImport]
public interface ISomeInterface
{
     [return: MarshalAs(UnmanagedType.LPWStr)]
     string SomeMethod([MarshalAs(UnmanagedType.LPWStr)] string text);
}

C ++:

class SomeClass
{
    virtual int32_t __stdcall _someMethod(const char16_t *text, char16_t **r) = 0;

    char16_t * someMethod(const char16_t *text)
        {
            char16_t * result;
            _someMethod(text, &result);
            return result; // how to correct release this memory?
        }
}

该解决方案适用于Windows和Linux。

1 个答案:

答案 0 :(得分:0)

假设您调用的对象具有如下的COM签名:

interface MyObj
{
   HRESULT __stdcall MethodOrProp([out, retval] BSTR* SomeStringReturned);
};

然后,你调用SysFreeString。

MyObj* pObj;
// ....

BSTR bstr = NULL;
HRESULT hr = pObj->MethodOrProp(&bstr);
if (SUCCEEDED(hr))
{
   // ... do junk with string ...
   SysFreeString(bstr);
}

但是,如果您使用的是Visual Studio,那么请不要担心它并使用CComBSTR。它将在析构函数中为您进行清理。

CComBSTR ccbString = NULL;
HRESULT hr = pObj->MethodOrProp(&ccbString);
if (SUCCEEDED(hr))
{
   // ... do junk with string ...
}
// some time at end of scope, destructor of ccbString will clean it up