溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Kotlin中的handler如何避免內(nèi)存泄漏詳解

發(fā)布時間:2020-08-24 19:06:09 來源:腳本之家 閱讀:262 作者:Donkor- 欄目:移動開發(fā)

前言:

哲學老師說,看待事物無非是了解它是什么,為什么,怎么做

所以,首先,我們先了解一下什么是“內(nèi)存泄漏”

摘自百度的一段話:用動態(tài)存儲分配函數(shù)動態(tài)開辟的空間,在使用完畢后未釋放,結(jié)果導致一直占據(jù)該內(nèi)存單元。直到程序結(jié)束。

是不是有點拗口,換一種說法,有天你去一家飯店吃飯,有個胖子吃完飯了,卻霸占著一張桌子不走,然而現(xiàn)在一堆人等著吃飯,結(jié)果那死胖子等到飯店打烊了才離開。

在這個例子中,飯店的桌子就好比內(nèi)存空間,那個胖子就是一個函數(shù),吃飯就是所執(zhí)行的事件。

這么說是不是好理解多了,現(xiàn)在,我們要做的就是趕走這個死胖子。

Handler在Android開發(fā)中經(jīng)常使用,一不小心就會陷入內(nèi)存泄漏的問題,最近在開發(fā)一款Kotlin軟件,針對Handler內(nèi)存泄漏的問題做出了解決方案

問題分析:

在finish()的時候,Message還沒有被處理,Message持有Handler, Handler持有Activity,這樣阻止了GC對Acivity的回收,就發(fā)生了內(nèi)存泄露。正確的寫法應該是使用顯形的引用,靜態(tài)內(nèi)部類與 外部類。使用弱引用WeakReference。 最后在Activity調(diào)用onDestroy()的時候要取消掉該Handler對象的Message和Runnable

核心代碼:

 private class MyHandler(activity: thisActivity) : Handler() {
  private val mActivity: WeakReference<thisActivity> = WeakReference(activity)
  override fun handleMessage(msg: Message) {
   if (mActivity.get() == null) {
    return
   }
   val activity = mActivity.get()
   when (msg.what) {
    0-> {
    }
    else -> {
    }
   }
  }
 }
 override fun onDestroy() {
  // Remove all Runnable and Message.
  MyHandler(this).removeCallbacksAndMessages(null)
  super.onDestroy()
 }

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI