JNA内存泄漏

JNA Memory Leak

本文关键字:泄漏 内存 JNA      更新时间:2023-10-16

给定此C++代码:

void LoadData(char** myVar)
{
    std:: string str("[Really Long String Here]");
    unsigned int size = str.length() + 1;
    *myVar = new char[size];
    strncpy(*myVar, str.c_str(), size);
}

这个JNA Java:

Pointer myVar = new Memory(Pointer.SIZE);
this.Lib.LoadData(myVar);
this.someVar = myVar.getPointer(0).getString(0);

我有内存泄漏,据我所知,getPointer(0)应该创建一个指针对象,该对象应该在finalize()上发布,但似乎不是。

我是不是错过了什么?这似乎符合规范…并且我可以在C++fine中运行上面的函数而不会泄漏。

我在循环中调用Java代码来测试泄漏,我尝试过暂停,并手动调用GC,这样它也会很快膨胀到千兆字节。

几天来,我一直在思考这个问题,被一些琐碎的事情所困扰,比如试图释放内存,真是太糟糕了。据我所知,如果我有地址,我只能在Java中手动释放内存,但我不知道该怎么得到。

编辑:

无论如何,我甚至不认为有一种方法可以在不扩展JNA的情况下通过JNA手动释放…

将此函数添加到C++库。。。

void FreeData(char** myVar)
{
    delete [] *myVar;
}

然后把它变成JNA代码

Pointer myVar = new Memory(Pointer.SIZE);
this.Lib.LoadData(myVar);
this.someVar = myVar.getPointer(0).getString(0);
this.Lib.FreeData(myVar);

通过这种方式,您可以在C++中分配和删除内存。

分配给调用者,而不是被调用者。

例如:

int LoadData(char* buf, int maxlen) {
    std:: string str("[Really Long String Here]");
    strncpy(buf, str.c_str(), maxlen);
    if (str.length() < maxlen) 
        return str.length();
    return maxlen;
}

然后,当您从Java调用时,传入一个适当大小的byte[]。请注意,这种实现可能效率非常低,但其想法是,您通常不希望在一个上下文中分配内存,而在另一个上下文中将其释放。

而不是myVar=新字符[size]

使用

*myVar = malloc(size);
strncpy(*myVar, str.c_str(), size);

需要删除的数组如下:删除[]*myVar;

JNA显然不知道该怎么做。