Android 靜態(tài)變量導(dǎo)致的內(nèi)存泄漏問題

說的Android的內(nèi)存泄漏什湘,大家都會(huì)想到由全局static變量強(qiáng)引用當(dāng)前對(duì)象(e.g. activity)埠通,導(dǎo)致當(dāng)前對(duì)象生命周期結(jié)束的時(shí)候赎离,無法被gc回收,從而造成內(nèi)存泄漏。首先這個(gè)觀點(diǎn)是沒有問題的. 但是有人說這樣端辱,如果這個(gè)對(duì)象被頻繁創(chuàng)建銷毀梁剔,那么就會(huì)有多個(gè)對(duì)象無法被回收,泄漏.? 真實(shí)情況是這樣的嗎舞蔽。?

static變量是全局變量憾朴,存放在方法區(qū),是全局唯一的喷鸽。 在對(duì)象重新創(chuàng)建的時(shí)候众雷,該變量會(huì)重新賦值,那么其之前所引用的對(duì)象做祝。就沒有被gc roots引用砾省,理論上,是可以被gc回收的混槐,就是說编兄,如果在gc回收的情況下,最多只有一個(gè)對(duì)象被泄漏.? 真實(shí)情況是不是這樣呢声登。

下面我們通過一個(gè)簡(jiǎn)單的例子來看一下狠鸳。


public class MainActivityextends AppCompatActivity {

????private static final String TAG ="MainActivity";

????private static ContextmContext;

????ClassDemodemo =new ClassDemo();

? ?@Override

? ? protected void onCreate(Bundle savedInstanceState) {

????????????super.onCreate(savedInstanceState);

????????????setContentView(R.layout.activity_main);

????????????Log.d(TAG,"onCreate: ");

????????????mContext =this;

}

protected? void onDestroy(){

????????super.onDestroy();

????????Log.d(TAG,"onDestroy: ");

????}

}

public class ClassDemo {

private static final String TAG ="ClassDemo";

????public int[]arr =new int[10000];

????public ClassDemo(){

????????Log.d(TAG,"ClassDemo: ");

????}

}

使用AndroidStudio編譯安裝到手機(jī)上,并運(yùn)行悯嗓,然后點(diǎn)擊AndroidStudio->Run->Profile‘a(chǎn)pp’件舵,獲取當(dāng)前java heap信息. 關(guān)于Profile的用法,請(qǐng)參考

https://blog.csdn.net/yangjie5250/article/details/80264517?(因?yàn)檫@個(gè)當(dāng)時(shí)沒有截圖脯厨,懶得重新運(yùn)行了铅祸,所以請(qǐng)參考其他文章)

直接運(yùn)行,打開app,這個(gè)時(shí)候執(zhí)行dump heap临梗,我們看結(jié)果涡扼。 只有一個(gè)MainActivity對(duì)象。? 注意左上角的選項(xiàng)盟庞。

Arrange by package. 這樣方便看一些吃沪。


然后按back鍵返回,再打開什猖,再返回巷波,重復(fù)多次。然后在重復(fù)上面的步驟卸伞,將heap 的情況dump出來抹镊。此時(shí)我們看到,此時(shí)有多個(gè)對(duì)象存在

另外你也可以看圖中的用圈圈住的那一列荤傲,那一列顯示對(duì)象個(gè)數(shù)垮耳。


從結(jié)果看,的確存在多個(gè)對(duì)象.? 那么是不是的確存在多個(gè)對(duì)象泄漏呢遂黍。 我們繼續(xù)操作

這次我們執(zhí)行 dump heap之前终佛,先強(qiáng)制執(zhí)行下GC ,點(diǎn)擊下圖中的 垃圾簍。 然后再執(zhí)行dump heap (點(diǎn)擊向下箭頭)雾家。再來看heap的情況


,

我們發(fā)現(xiàn)只剩下一個(gè)MainActivity了铃彰。 說明了什么. 說明了其他的對(duì)象,是可以gc 掉的芯咧,真正泄漏的只有一個(gè)對(duì)象牙捉。

總結(jié):

由全局靜態(tài)變量強(qiáng)引用當(dāng)前對(duì)象引起的內(nèi)存泄漏,不會(huì)因?yàn)椴粩嗟闹亟ㄤN毀對(duì)象而泄漏多個(gè)對(duì)象敬飒。最終只有一個(gè)被正在引用的對(duì)象泄漏邪铲,其他的對(duì)象都可以被gc回收掉. 至于同時(shí)存在多個(gè)對(duì)象的情況,是因?yàn)檫@個(gè)時(shí)候无拗,還沒有g(shù)c發(fā)生.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末带到,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子英染,更是在濱河造成了極大的恐慌揽惹,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件四康,死亡現(xiàn)場(chǎng)離奇詭異搪搏,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)箭养,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門慕嚷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來哥牍,“玉大人毕泌,你說我怎么就攤上這事喝检。” “怎么了撼泛?”我有些...
    開封第一講書人閱讀 165,747評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵挠说,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我愿题,道長(zhǎng)损俭,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評(píng)論 1 295
  • 正文 為了忘掉前任潘酗,我火速辦了婚禮杆兵,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘仔夺。我一直安慰自己琐脏,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評(píng)論 6 392
  • 文/花漫 我一把揭開白布缸兔。 她就那樣靜靜地躺著日裙,像睡著了一般。 火紅的嫁衣襯著肌膚如雪惰蜜。 梳的紋絲不亂的頭發(fā)上昂拂,一...
    開封第一講書人閱讀 51,737評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音抛猖,去河邊找鬼格侯。 笑死,一個(gè)胖子當(dāng)著我的面吹牛财著,可吹牛的內(nèi)容都是我干的养交。 我是一名探鬼主播,決...
    沈念sama閱讀 40,448評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼瓢宦,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼碎连!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起驮履,我...
    開封第一講書人閱讀 39,352評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤鱼辙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后玫镐,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體倒戏,經(jīng)...
    沈念sama閱讀 45,834評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評(píng)論 3 338
  • 正文 我和宋清朗相戀三年恐似,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了杜跷。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,133評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖葛闷,靈堂內(nèi)的尸體忽然破棺而出憋槐,到底是詐尸還是另有隱情,我是刑警寧澤淑趾,帶...
    沈念sama閱讀 35,815評(píng)論 5 346
  • 正文 年R本政府宣布阳仔,位于F島的核電站,受9級(jí)特大地震影響扣泊,放射性物質(zhì)發(fā)生泄漏近范。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評(píng)論 3 331
  • 文/蒙蒙 一延蟹、第九天 我趴在偏房一處隱蔽的房頂上張望评矩。 院中可真熱鬧,春花似錦阱飘、人聲如沸稚照。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽果录。三九已至,卻和暖如春咐熙,著一層夾襖步出監(jiān)牢的瞬間弱恒,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工棋恼, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留返弹,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,398評(píng)論 3 373
  • 正文 我出身青樓爪飘,卻偏偏與公主長(zhǎng)得像义起,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子师崎,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容