作者minesos520 (!!!)
看板AndroidDev
標題[問題] static context 的問題
時間Tue Nov 7 17:07:05 2017
想請教
若 static 的view 持有 context
會有memory leak的問題
那反過來
如果一般 View 帶入 static 的 context
會有相同的問題嗎?
會因為引用 static 的 context
導致無法被回收嗎?
感謝!
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 220.130.50.211
※ 文章網址: https://webptt.com/m.aspx?n=bbs/AndroidDev/M.1510045630.A.FED.html
1F:→ ab18282099: static的Context基本上就有可能會memory leak了 11/07 17:33
2F:→ lnmlee: static 最好不要用在 基本型態跟String 以外的物件 11/07 17:37
3F:→ minesos520: 因為架構是一個acticity疊fragment,所以acticity基本 11/07 18:43
4F:→ minesos520: 上不會死 11/07 18:43
5F:→ minesos520: 所以用static方便使用,只是不確定這樣帶入toast或dia 11/07 18:44
6F:→ minesos520: log會不會有影響 11/07 18:44
7F:→ ssccg: memory leak這件事是持有別的物件的reference,會導致被參 11/07 18:49
8F:→ ssccg: 照的物件不會被回收,反過來就沒有差 11/07 18:49
9F:→ ssccg: 但是context只有application是static,activity即使只有一 11/07 18:50
10F:→ ssccg: 個,每次系統重建也都是不同的物件,不是同一個 11/07 18:50
11F:→ ssccg: 如果用static reference存activity,那在更新此reference前 11/07 18:51
12F:→ ssccg: 不管被指到的activity是死是活都不會被回收,也是種leak 11/07 18:52
13F:→ lnmlee: 在Fragment 裡 new View(getActivity()); 就能解決原po的 11/07 19:07
14F:→ lnmlee: 問題 Fragment 有個 getActivity(); method 可以找父層Act 11/07 19:07
15F:→ lnmlee: ivity Context 11/07 19:07
16F:→ minesos520: 嗯嗯我知道,只是好奇New view(static context)的話, 11/07 19:18
17F:→ minesos520: view會因此不被回收嗎? 11/07 19:18
18F:→ lnmlee: 你可以用debug mode 追看看 11/07 20:16
19F:→ lnmlee: 我的理解是Activity lifecycle 讓 context 指向 null 而連 11/07 20:21
20F:→ lnmlee: 帶所有 使用的view 被指向 null 最後就是垃圾車來收垃圾了 11/07 20:21
21F:→ ssccg: 不是指向null,GC是從特定root物件(如stack、static變數)出 11/07 21:06
22F:→ ssccg: 發,所有能到達的物件就視為使用中,無法到達的就會被清掉 11/07 21:07
23F:→ ssccg: View裡有變數指向static物件,但View自己沒被使用中的物件 11/07 21:10
24F:→ ssccg: 指到的話,還是會清掉。Activity是使用中時系統會保持一個 11/07 21:11
25F:→ ssccg: 參考,在結束時會釋放,但另外有static變數指向Activity就 11/07 21:13
26F:→ ssccg: 會造成系統已不用的Activity不會被清掉 11/07 21:13
27F:→ ssccg: View在沒有另外用變數存的情況下,通常指向它的只有上一層 11/07 21:15
28F:→ ssccg: 的View,在被移除出View hierarchy時就可以被清掉了 11/07 21:16
29F:→ lnmlee: 所以context 就是一個追蹤是否連著root物件 以利於GC thre 11/07 21:59
30F:→ lnmlee: ad 啟動時ㄧ起記憶體初始化 的媒介對吧? 11/07 21:59
31F:→ twntwn: 不會 11/11 15:29