Android JNI Attempt to remove non-JNI local reference, dumping thread

Attempt to remove non-JNI local reference, dumping thread

解决办法:

去除Jni代码

env->DeleteLocalRef(javaObject);

注意:是java层传递给jni层的对象不需用了DeleteLocalRef来进行对象删除,jni层创建的对象仍然需要保留代码。

这个是jni代码的问题,jni层创建的jobject使用完之后需要进行删除,否则会出现栈内存满而crash。

void Event::OnNavigate(const std::string &strurl)
{
    jstring jurl = str2jstring(m_jniEnv,strurl.c_str()); //jurl是JNI创建的jobject对象
    m_jniEnv->CallVoidMethod(javaEventObject,javaEvent_OnNavigateID, jurl);
    m_jniEnv->DeleteLocalRef(jurl);//对象用完之后需要删除
}

但java层传递给jni的对象不需要进行删除:

JNIEXPORT jboolean JNICALL Java_com_eagle_routine_ERoutinee_navigate(JNIEnv * env, jobject object,jstring url){
    std::string strUrl= JstringToCString(env, url);//url 是java层传递的jobject对象,使用完之后不用删除
    return routine->Navigate(strUrl);
}

android 8.0以下的系统会输出这样的日志,当然这个是给警告日志,也可以不用理会,但看着始终不爽。

你可能感兴趣的:(移动开发,Android,jni,android,java)