Android JNI Attempt to remove non-JNI local reference, dumping thread
生活随笔
收集整理的這篇文章主要介紹了
Android JNI Attempt to remove non-JNI local reference, dumping thread
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
Attempt to remove non-JNI local reference, dumping thread
解決辦法:
去除Jni代碼
env->DeleteLocalRef(javaObject);注意:是java層傳遞給jni層的對(duì)象不需用了DeleteLocalRef來(lái)進(jìn)行對(duì)象刪除,jni層創(chuàng)建的對(duì)象仍然需要保留代碼。
這個(gè)是jni代碼的問題,jni層創(chuàng)建的jobject使用完之后需要進(jìn)行刪除,否則會(huì)出現(xiàn)棧內(nèi)存滿而crash。
void Event::OnNavigate(const std::string &strurl) {jstring jurl = str2jstring(m_jniEnv,strurl.c_str()); //jurl是JNI創(chuàng)建的jobject對(duì)象m_jniEnv->CallVoidMethod(javaEventObject,javaEvent_OnNavigateID, jurl);m_jniEnv->DeleteLocalRef(jurl);//對(duì)象用完之后需要?jiǎng)h除 }但java層傳遞給jni的對(duì)象不需要進(jìn)行刪除:
JNIEXPORT jboolean JNICALL Java_com_eagle_routine_ERoutinee_navigate(JNIEnv * env, jobject object,jstring url){std::string strUrl= JstringToCString(env, url);//url 是java層傳遞的jobject對(duì)象,使用完之后不用刪除return routine->Navigate(strUrl); }android 8.0以下的系統(tǒng)會(huì)輸出這樣的日志,當(dāng)然這個(gè)是給警告日志,也可以不用理會(huì),但看著始終不爽。
總結(jié)
以上是生活随笔為你收集整理的Android JNI Attempt to remove non-JNI local reference, dumping thread的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Guava常用工具类的使用
- 下一篇: android sina oauth2.