Android中內存泄漏的注意點有哪些,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
創(chuàng)新互聯建站是一家做網站、網站制作,提供網頁設計,網站設計,網站制作,建網站,按需定制制作,網站開發(fā)公司,成立于2013年是互聯行業(yè)建設者,服務者。以提升客戶品牌價值為核心業(yè)務,全程參與項目的網站策劃設計制作,前端開發(fā),后臺程序制作以及后期項目運營并提出專業(yè)建議和思路。
內存泄漏對每一位 Android 開發(fā)一定是司空見慣,大家或多或少都肯定有些許接觸。大家都知道,每一個手機都有一定的承載上限,多處的內存泄漏堆積一定會堆積如山,最終出現內存爆炸 OOM。
而這,也是極有可能在 Android 面試中一道常見的開放題。
內存泄漏的根本原因是一個長生命周期的對象持有了一個短生命周期的對象。如果你對垃圾回收機制有所了解,我想這個問題基本難不住你,因為知道了原理,自然不會去觸碰這些極易導致內存泄漏的雷區(qū)。
該題重在積累,不需要死記硬背,自己多總結即可。
1. 長生命周期對象持有 Activity
這基本是最常見的內存泄漏了,比如
內部類形式使用 Handler 同時發(fā)送延時消息,或者在 Handler 里面執(zhí)行耗時任務,在任務還沒完成的時候 Activity 需要銷毀。這時候由于 Handler 持有 Activity 的強引用導致 Activity 無法被回收。
同理內部類形式的使用 AsyncTask 執(zhí)行耗時任務也會導致內存泄漏的發(fā)生。
單例作為最長生命周期的對象,自然不應該持有 Activity 從而導致內存泄漏發(fā)生;
針對上面這種情況,基本不必多說了,不要使用內部類或者匿名內部類做這樣的處理就好了,實際上 IDE 也會彈出警告,我想大家應該還是都知道采用靜態(tài)內部類或者在銷毀頁面的時候使用相關方法移除處理的。
Activity 中匿名使用 Handler 實際上會導致 Handler 內部類持有外部類的引用,而 SendMessage() 的時候 Message 會持有 Handler,enqueueMessage 機制又會導致 MeassageQueue 持有 Message。所以當發(fā)送的是延遲消息那么 Message 并不會立即的遍歷出來處理而是阻塞到對應的 Message 觸發(fā)時間以后再處理。那么阻塞的這段時間中頁面銷毀一定會造成內存泄漏。
2. 各種注冊操作沒有對應的反注冊
這一點基本不必多說,相信大家剛剛開始學習廣播和 Service 的時候一定對此有所接觸,然后就是比如我們常用的第三方框架 EventBus 也是一樣的。平時使用的時候注意在對應的生命周期方法中進行反注冊。
3. Bitmap 使用完沒有注意 recycle()
Bitmap 作為大對象,在使用完畢一定要注意調用 recycle() 進行回收。TypedArray 、Cursor、各種流同理,一定要在最后調用自己的回收關閉方法處理。
4. WebView 使用不當
WebView 是非常常用的控件,但稍有不注意也會導致內存泄漏。內存泄漏的場景: 很多人使用 Webview 都喜歡采用布局引用方式, 這其實也是作為內存泄漏的一個隱患。當 Activity 被關閉時,Webview 不會被 GC 馬上回收,而是提交給事務,進行隊列處理,這樣就造成了內存泄漏, 導致 Webview 無法及時回收。
目前所知的比較安全的方案是:
在布局中動態(tài)添加 WebView。
采用下面的方法。
override fun onDestroy() { webView?.apply { val parent = parent if (parent is ViewGroup) { parent.removeView(this) } stopLoading() // 退出時調用此方法,移除綁定的服務,否則某些特定系統(tǒng)會報錯 settings.javaScriptEnabled = false clearHistory() removeAllViews() destroy() }}
5. 循環(huán)引用
循環(huán)引用導致內存泄漏比較少見,正常來講不會有人寫出 A 持有 B,B 持有 C,C 又持有A 這樣的代碼,不過總還是需要注意。
總的來說,內存泄漏很常見,但檢測方式也很多。我們的 Android Studio 自帶的 Monitors 就可以幫我們找到大部分內存問題,當然我們也可以采用譬如 LeakCanary 這樣的庫去做檢測。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯行業(yè)資訊頻道,感謝您對創(chuàng)新互聯的支持。