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以下的系统会输出这样的日志,当然这个是给警告日志,也可以不用理会,但看着始终不爽。