gpt4 book ai didi

java - 字节数组的 JNI 内存泄漏

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:54:31 29 4
gpt4 key购买 nike

我有一个 java 程序多次调用 native 函数。我的问题是这个函数有内存泄漏,我为摆脱它所做的一切都会导致内存转储。任何帮助将不胜感激。

这是我的代码

JNIEXPORT void JNICALL Java_class_method_getInput
(JNIEnv *env, jobject obj)
{
if (inputIsAvailable)
{

int size = getBufferCurrentIndex();
size -= getBufferReadIndex();
size *= 2;

char *finalSendArray = new char[size];

getCommand(finalSendArray);

jbyteArray byteArray = env->NewByteArray(size / 2);
env->SetByteArrayRegion(byteArray, 0, size / 2, (jbyte*) finalSendArray);

while(methodID == 0)
{
jclass cls = env->GetObjectClass(obj);
methodID = env->GetMethodID(cls, "setCommand", "([B)V" );
}

env->CallVoidMethod(obj, methodID, byteArray);

//env->ReleaseByteArrayElements(byteArray, (jbyte*) finalSendArray, JNI_ABORT);

我的问题是上面的 ^ 代码如果没有注释会导致内存转储,如果没有注释我的程序会在几分钟内耗尽内存

    env->DeleteLocalRef(byteArray);
delete[] finalSendArray;
}
}

如有任何帮助,我们将不胜感激。谢谢!

最佳答案

如果您使用 JNI_ABORT 参数,ReleaseByteArrayElements 也将释放内存。因此,当您稍后执行删除和释放时,其中一个指针指向导致转储的未初始化内存。

其中一个会起作用,我相当确定它是第一个起作用的。

env->ReleaseByteArrayElements(byteArray, (jbyte*) finalSendArray, JNI_ABORT);
delete[] finalSendArray;

如果第一个失败,试试这个。

env->ReleaseByteArrayElements(byteArray, (jbyte*) finalSendArray, JNI_ABORT);
env->DeleteLocalRef(byteArray);

在 ReleaseByteArrayElements 之后放置一个 print 语句,您将看到您的程序执行超出该命令并在 Release/Delete[] 上崩溃

Search for "Table 4-10 Primitive Array Release Modes"

关于java - 字节数组的 JNI 内存泄漏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18668135/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com