微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

在 DLL 中使用 new 分配内存 - 如何释放?

如何解决在 DLL 中使用 new 分配内存 - 如何释放?

我在 DLL 中有许多输出指针的导出函数,它们在这函数中分配内存。例如:

DLL_EXPORT void some_function(const char*** param)
{
    *param= new const char*[somenumber];
    //someting
    //in some for-cycle
    char* somestr = new char[somenumber1];
    strcpy(somestr,somelocalstr);
    //someting
}

它在其他项目中是这样使用的(我不会在这里LoadLibrary()GetProcAddress(),它已经完成了):

void some_function_that_uses_dll()
{
    const char** param;
    some_function(&param); 
    //something
    //some for-cycle
    const char* somestring = param[i];
    //something
    non_local_std_string = somestring;
}

这就是我收到项目的方式。

这里似乎发生了明显的内存泄漏。但是当我尝试在 delete[] somestring; 之后写入 non_local_std_string = somestring; 时,我遇到了崩溃。可能是因为项目不同。

有没有办法在 DLL 中分配的内存被复制到 std::string (non_local_std_string) 之后释放它们?或者,std::string 是否移动了这些记忆?

解决方法

不,std::string 不会获得分配的内存的所有权。 DLL 的用户负责在使用完后释放内存,例如将其复制到 std::string 中。

在这种情况下,您必须:

  1. 导出一个附加函数,DLL 的用户在使用完数组后必须调用该函数来 delete[],例如:
DLL_EXPORT int some_function(char*** param)
{
    *param = nullptr;
    int res = 0;

    try
    {
        *param = new char*[somenumber];
        for(int i = 0; i < somenumber; ++i)
        {
            ...
            char* somestr = new char[somenumber1];
            strcpy(somestr,somelocalstr);
            (*param)[res] = somestr;
            ++res;
        }
    }
    catch (...)
    {
        for(int i = 0; i < res; ++i) {
            delete[] (*param)[i];
        }
        delete[] *param;
        return -1;
    }

    return res;
}

DLL_EXPORT void free_function(char** param,int n)
{
    for(int i = 0; i < n; ++i) {
        delete[] param[i];
    }
    delete[] param;
}
void some_function_that_uses_dll()
{
    char** param;
    int n = some_function(&param); 

    for(int i = 0; i < n; ++i)
    {
        char* somestring = param[i];
        //...
    }

    free_function(param,n);
}
  1. 使用操作系统提供的内存管理函数而不是 new[]/delete[] 分配和释放数组。这样,DLL 的用户就可以直接调用 OS 函数,例如:
DLL_EXPORT int some_function(char*** param)
{
    *param = (char**) LocalAlloc(LMEM_FIXED,sizeof(char*) * somenumber);
    if (*param == NULL) return -1;

    int res = 0;

    for(int i = 0; i < somenumber; ++i)
    {
        ...
        char* somestr = (char*) LocalAlloc(LMEM_FIXED,sizeof(char) * somenumber1);
        if (somestr == NULL)
        {
            for(int j = 0; j < res; ++j) {
                LocalFree((*param)[j]);
            }
            LocalFree(*param);
            return -1;
        }
        
        strcpy(somestr,somelocalstr);
        (*param)[res] = somestr;
        ++res;
    }

    return res;
}
void some_function_that_uses_dll()
{
    const char** param;
    int n = some_function(&param); 

    for(int i = 0; i < n; ++i)
    {
        char* somestring = param[i];
        //...
    }

    for(int i = 0; i < n; ++i) {
        LocalFree(param[i]);
    }
    LocalFree(param);
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。