當前位置:首頁 > 公眾號精選 > 程序喵大人
[導讀]最近開發(fā)過程中遇到了JNI的Reference相關問題,了解到Local Reference和Global Reference的相關知識點,整理如下: 背景:項目需求,在Native C/C++層調用上層Android Camera Java接口,把所有的操作包括Camera都沉到Native層去實現(xiàn)。但在JNI調試過程中遇到了


最近開發(fā)過程中遇到了JNI的Reference相關問題,了解到Local Reference和Global Reference的相關知識點,整理如下:

背景:項目需求,在Native C/C++層調用上層Android Camera Java接口,把所有的操作包括Camera都沉到Native層去實現(xiàn)。但在JNI調試過程中遇到了android JNI ERROR (app bug): accessed stale local reference的報錯。

現(xiàn)象:在Native層創(chuàng)建Java的Camera對象,其對象的指針保存到本地,函數(shù)返回到Java層,之后再進入Native層,想通過Native層的Camera對象指針調用相應的方法,但是發(fā)現(xiàn)每次都是重新調用Java對象方法后報錯。

分析:在Native層創(chuàng)建的Java對象,對象創(chuàng)建后會有一個局部引用指向該對象,當從Native環(huán)境返回到Java環(huán)境,該局部引用失效,此對象就沒有引用計數(shù),Java的內存回收機制會自動回收該對象,第二次再進入Native層訪問其之前保存的地址時就會報錯。

解決:使用全局引用始終持有該對象的引用使其不被自動回收,請看下面的知識點。

Local Reference

局部引用,看如下精簡代碼:

env->NewStringUTF("0");

在JNI中,每次調用NewObject方法創(chuàng)建一個新的對象都會返回一個對該對象的局部引用(Local Reference),該局部引用只在線程當前的Native環(huán)境中有效,返回到Java環(huán)境后該引用與對象之間的聯(lián)系就會被斷掉,引用失效,所以我們不能在Native方法中把局部引用緩存用于下一次調用時使用。

局部引用可以無限創(chuàng)建嗎?

如圖:


這里引入局部引用表的概念,每當線程從Java環(huán)境進入到Native環(huán)境后,JVM就會創(chuàng)建該線程Native環(huán)境的局部引用表,用來保存本次Native環(huán)境所創(chuàng)建的所有局部引用,每當Native中引用或者新創(chuàng)建一個Java對象,JVM就會局部引用表創(chuàng)建一個局部引用,局部引用表是有大小限制的,最大是512,如果超過限制會報OOM內存泄漏。

Q:那如何才能更好的避免由于局部引用過多造成Native環(huán)境中的OOM呢?

A:控制局部引用的生命周期,如果需要創(chuàng)建過多的局部引用,可以在Java對象的操作結束后,手動調用DeleteLocalRef函數(shù)刪除局部引用,該局部引用就會在局部引用表中被移除,避免觸發(fā)局部引用表的大小限制。

注意:局部引用不是我們平時所理解的代碼中的局部變量,局部變量在當前生命周期(例如函數(shù)退出)結束后就會失效,而局部引用在函數(shù)退出后可能不會失效,它的生命周期是和整個Native上下文環(huán)境相關聯(lián),只有從Native環(huán)境返回到Java環(huán)境后局部引用才會失效。

Global Reference

全局引用,終于到了最上面討論的問題了,因為局部引用在Native環(huán)境返回到Java環(huán)境后就會失效,導致下次進入Native環(huán)境后再次使用相對應的Java對象就會出錯,所以可以使用全局引用來解決這個問題,全局引用可以始終與Java對象保持聯(lián)系,使得此對象不會被JVM回收掉,見如下代碼:

JNIEXPORT jint JNICALL JNI_OnLoad (JavaVM * vm, void * reserved) {  jclass tmp = env->FindClass("com/example/company/MyClass");  jclass class = env->NewGlobalRef(tmp); return JNI_VERSION_1_6; }

這里需要注意,在不需要使用Java對象后盡量手動調用DeleteGlobalRef()函數(shù)來使得引用失效,避免對象始終存在,產生潛在的內存泄漏。

Weak Global Reference

虛全局引用與全局引用的區(qū)別在于該類型的引用可能隨時被JVM回收掉,這里涉及到幾個函數(shù):

NewWeakGlobalRef();DeleteWeakGlobalRef();isSameObject();

在使用虛引用前需要通過isSameObject將其和NULL比較,如果返回true表示已經被JVM回收掉就不能使用了,這里有可能前一行代碼判斷還是可用,后一行代碼時就被JVM回收,解決辦法是通過NewLocalRef()獲取虛全局引用,避免當時被JVM回收。

參考資料

https://www.cnblogs.com/zhongshujunqia/p/4638077.html?utm_source=tuicool&utm_medium=referral
https://www.cnblogs.com/younghome/p/4609044.html
https://stackoverflow.com/questions/14765776/jni-error-app-bug-accessed-stale-local-reference-0xbc00021-index-8-in-a-tabl
https://www.ibm.com/developerworks/cn/java/j-lo-jnileak/index.html
https://juejin.im/post/5c19bfa0f265da6133568545



c++11新特性,所有知識點都在這了!

你的c++團隊還在禁用異常處理嗎?

內存對齊之格式修訂版

c++11新特性之智能指針

gcc a.c 究竟經歷了什么?

談談程序鏈接及分段那些事

免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉