內存泄露記錄

原本以為android內存泄露會是大牛才該解決的問題。可是公司就我一個Android啊,代碼都是你寫的啊,工具持續用一個小時就開始卡頓了,甚至崩潰,你不解決誰解決啊。

于是乎,開始查什么叫內存泄露,內存溢出。看了一大堆文章不是我想要的。從解決結果來說,程序中存在不合理的代碼,比如handler,計時器,注冊的服務廣播什么的沒關閉,導致activity關閉的時候,資源沒有被系統回收,內存沒有被釋放,反復操作,內存占用越來越多,知道逼近系統分配給你應用的最大內存,程序開始卡頓,直至崩潰。

那么接下來有幾個問題,問題1,一般應用在android studio中的memory應該是多少呢,我測試我的軟件是啟動8M多一點,打開兩三個界面后到16M左右,設備是專用測量設備南方x2,然后打開內存泄露那個界面,關閉后到達20M,反復打開關閉,最終好像有40M,不過我也沒耐心測試一個小時,既然知道了這里內存異常了。附as查看應用占用內存情況

然后,開始百度搜索(用百度會不會被用google的鄙視)如何解決內存溢出。最終鎖定leakcanary。gradle引用

debugCompile'com.squareup.leakcanary:leakcanary-android:1.4-beta2'

releaseCompile'com.squareup.leakcanary:leakcanary-android-no-op:1.4-beta2'

application中添加

private RefWatcher mRefWatcher;

public voidonCreate() {

mRefWatcher= LeakCanary.install(this);

}

public static RefWatcher getRefWatcher(Context context){

MyApplication baseApplication = (MyApplication) context.getApplicationContext();

return baseApplication.mRefWatcher;

}

然后在BaseAcitivity(沒有封裝一層直接在每個activity中)的ondestroy中添加MyApplication.getRefWatcher(this).watch(this);

然后運行程序就好了,當關閉activity時有內存泄露的話,屏幕上會有個彈窗提示,然后可以去系統通知欄查看。或者你會發現你多了一個應用程序leaks,打開后發現


然后發現一個activity4.5M內存泄露,驚不驚喜,意不意外,年幼無知的我還不知道4.5M是什么概念,直到我測試出別的界面有內存泄露,不過是100K,13k的時候,我才意識到這個4.5M,真尼瑪大啊。然后看錯誤,第一反應數據庫操作cursor沒有及時關閉,editTextWatche只是add了,我以前從來不知道還需要remove啊。然后進行了查找cursor有沒有沒關閉,remove了textwatcher。再次運行依然這幾處地方報錯,日了uzi了。后來故意在一個界面不關閉游標,運行,竟然沒有報數據庫的錯誤。最終折騰了一下午,掉到這兩個地方有錯誤的圈里出不來了,也沒解決問題。不過后來再改別的地方是發現一個計時器沒有管,聯想到了這個界面有個自定義動畫,果然,這里也有個計時器沒關閉,然后關閉了。運行沒有內存溢出了。現在程序穩穩的13M左右運行。問題來了,為什么沒有直接指出計時器導致的內存泄露,而是指向這么一些沒有真正錯誤的東西,還有這個東西該怎么讀啊?

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,533評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,055評論 3 414
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,365評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,561評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,346評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,889評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,978評論 3 439
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,118評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,637評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,558評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,739評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,246評論 5 355
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,980評論 3 346
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,362評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,619評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,347評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,702評論 2 370

推薦閱讀更多精彩內容