Android JNI Attempt to remove non-JNI local reference, dumping thread
生活随笔
收集整理的這篇文章主要介紹了
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 Attempt to remove non-JNI local reference, dumping thread的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Guava常用工具类的使用
- 下一篇: JVM——详解类加载过程