4

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

这是我的代码

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;
    }
}

任何帮助,将不胜感激。谢谢!

4

1 回答 1

4

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

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

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

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

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

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

搜索“表 4-10 原始阵列释放模式”

于 2013-09-07T00:06:26.897 回答