ThreadLocal簡單的總結(jié)

每個(gè)線程都有一個(gè)threadLocals對(duì)象 其實(shí)質(zhì)是一個(gè)鏈表
鏈表的每個(gè)元素就是一個(gè)entry企垦,這個(gè)entry的key是WeakReference<threadlocal>,value則是我們?cè)O(shè)置值
所以這就意味著 當(dāng)我們?cè)O(shè)置多個(gè)threadlocal對(duì)象則在thread的threadLocals中就有多個(gè)entry扳躬。
因?yàn)閑ntry的key是弱引用,其會(huì)在jvm發(fā)生gc(無論是minor 姚垃,major歇父,full gc)之后被回收。
內(nèi)存泄漏
1.比如我們的key 因?yàn)間c 被回收 但是value 則永遠(yuǎn)無法在訪問
解決方案:在ThreadLocal的get(),set(),remove()的時(shí)候都會(huì)清除線程ThreadLocalMap里所有key為null的value沙合。

2.就是我們的線程一直不結(jié)束奠伪,且也一直不使用上述三個(gè)方法的api,或者就算使用了get和set但是一直 沒使用remove 而在此期間key也沒有回收首懈,這就導(dǎo)致這個(gè)內(nèi)存一值被占用绊率。

Threadlocal

一個(gè)threadlocal對(duì)象為每一個(gè)線程創(chuàng)建一個(gè)類似map(其實(shí)是數(shù)組內(nèi)部存儲(chǔ)一個(gè)entry對(duì)象,entry的key是弱引用包裝的threadlocal value就是我們?cè)O(shè)置的值)
這個(gè)map會(huì)賦值給該線程 作為線程的一個(gè)屬性究履!因此這邊需要注意的是當(dāng)我們用多個(gè)threadlocal操作一個(gè)線程 則map里面包含的數(shù)據(jù)就是多個(gè)滤否!

弱引用對(duì)象會(huì)在threadlocal被jvm gc的時(shí)候被回收(沒有任何強(qiáng)引用指向threadlocal實(shí)例)放入到隊(duì)列中(如果我沒又設(shè)置隊(duì)列則不放入隊(duì)列)

內(nèi)存溢出或者內(nèi)存泄漏的原因
我們這樣一般很少會(huì)用很多threadlocal對(duì)象操作線程,所以一般都是一個(gè)threadlocal對(duì)應(yīng)多個(gè)線程
那么就相當(dāng)于每個(gè)線程都攜帶一個(gè)map 一個(gè)map包含這個(gè)弱引用的threadlocal的key和對(duì)應(yīng)value

一般內(nèi)存異常是指多個(gè)線程都沒有回收map中的結(jié)果進(jìn)而導(dǎo)致內(nèi)存溢出最仑,當(dāng)然也可以理解為內(nèi)存泄漏
因?yàn)樵谶@段時(shí)間我們不使用他們 也不刪除藐俺。這就導(dǎo)致內(nèi)存一直被占用但是無法釋放!

當(dāng)我們使用的threadlocal不是全局對(duì)象 是可以被回收的 那么我們的map中就有可能存在key為null情況這就導(dǎo)致我們無法使用我們value
這才是真正的內(nèi)存泄漏泥彤,而對(duì)于上述key不為null還

所以 如果我們定義一個(gè)全局變量threadlocal 那么對(duì)于單線程 就算我們?cè)O(shè)置了 不刪除 也不會(huì)有內(nèi)存泄漏欲芹,但是對(duì)于線程池 或者遲遲不結(jié)束的線程!
那么我們不刪除threadlocal 那么我們下次在使用會(huì)覆蓋的吟吝。
但是我們定義一個(gè)局部變量threadlocal 那么對(duì)于線程池 或者遲遲不結(jié)束的線程菱父! 則有可能存在key是null的內(nèi)存泄漏數(shù)據(jù)!
所以我們需要解決這個(gè)內(nèi)存泄漏
而對(duì)于set get remove都會(huì)刪除key=null的entry
但是需要注意的是 其必須遇到key=null時(shí)候才會(huì)刪除,如果我們get的時(shí)候就算有key=null的情況 但是沒遇上則是不會(huì)刪除的

key 使用強(qiáng)引用:引用的ThreadLocal的對(duì)象被回收了滞伟,但是ThreadLocalMap還持有ThreadLocal的強(qiáng)引用揭鳞,如果沒有手動(dòng)刪除,ThreadLocal不會(huì)被回收梆奈,導(dǎo)致Entry內(nèi)存泄漏野崇。
key 使用弱引用:引用的ThreadLocal的對(duì)象被回收了,由于ThreadLocalMap持有ThreadLocal的弱引用亩钟,即使沒有手動(dòng)刪除乓梨,ThreadLocal也會(huì)被回收。value在下一次ThreadLocalMap調(diào)用set,get清酥,remove的時(shí)候會(huì)被清除扶镀。
比較兩種情況,我們可以發(fā)現(xiàn):由于ThreadLocalMap的生命周期跟Thread一樣長焰轻,如果都沒有手動(dòng)刪除對(duì)應(yīng)key臭觉,都會(huì)導(dǎo)致內(nèi)存泄漏,但是使用弱引用可以多一層保障:弱引用ThreadLocal不會(huì)內(nèi)存泄漏辱志,對(duì)應(yīng)的value在下一次ThreadLocalMap調(diào)用set,get,remove的時(shí)候會(huì)被清除蝠筑。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市揩懒,隨后出現(xiàn)的幾起案子什乙,更是在濱河造成了極大的恐慌,老刑警劉巖已球,帶你破解...
    沈念sama閱讀 211,817評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件臣镣,死亡現(xiàn)場離奇詭異,居然都是意外死亡智亮,警方通過查閱死者的電腦和手機(jī)忆某,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,329評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來阔蛉,“玉大人褒繁,你說我怎么就攤上這事♀珊觯” “怎么了棒坏?”我有些...
    開封第一講書人閱讀 157,354評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長遭笋。 經(jīng)常有香客問我坝冕,道長,這世上最難降的妖魔是什么瓦呼? 我笑而不...
    開封第一講書人閱讀 56,498評(píng)論 1 284
  • 正文 為了忘掉前任喂窟,我火速辦了婚禮测暗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘磨澡。我一直安慰自己碗啄,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,600評(píng)論 6 386
  • 文/花漫 我一把揭開白布稳摄。 她就那樣靜靜地躺著稚字,像睡著了一般。 火紅的嫁衣襯著肌膚如雪厦酬。 梳的紋絲不亂的頭發(fā)上胆描,一...
    開封第一講書人閱讀 49,829評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音仗阅,去河邊找鬼昌讲。 笑死,一個(gè)胖子當(dāng)著我的面吹牛减噪,可吹牛的內(nèi)容都是我干的短绸。 我是一名探鬼主播,決...
    沈念sama閱讀 38,979評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼筹裕,長吁一口氣:“原來是場噩夢啊……” “哼醋闭!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起饶碘,我...
    開封第一講書人閱讀 37,722評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎馒吴,沒想到半個(gè)月后扎运,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,189評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡饮戳,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,519評(píng)論 2 327
  • 正文 我和宋清朗相戀三年豪治,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片扯罐。...
    茶點(diǎn)故事閱讀 38,654評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡负拟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出歹河,到底是詐尸還是另有隱情掩浙,我是刑警寧澤,帶...
    沈念sama閱讀 34,329評(píng)論 4 330
  • 正文 年R本政府宣布秸歧,位于F島的核電站厨姚,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏键菱。R本人自食惡果不足惜谬墙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,940評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧拭抬,春花似錦部默、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,762評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至累奈,卻和暖如春贬派,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背澎媒。 一陣腳步聲響...
    開封第一講書人閱讀 31,993評(píng)論 1 266
  • 我被黑心中介騙來泰國打工搞乏, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人戒努。 一個(gè)月前我還...
    沈念sama閱讀 46,382評(píng)論 2 360
  • 正文 我出身青樓请敦,卻偏偏與公主長得像,于是被迫代替她去往敵國和親储玫。 傳聞我的和親對(duì)象是個(gè)殘疾皇子侍筛,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,543評(píng)論 2 349

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