threadlocal可以簡單理解為key為當前thread的乙個map(簡單這麼理解(是簡單這麼理解,實際並不是),具體可參看:所以它和執行緒池一起使用的時候就會出現問題了,因為我們知道執行緒池有乙個好處就是會讓執行緒重用,避免建立過多的執行緒物件。也就是說有可能會出現threadlocal中的執行緒物件相同的情況,先上**看看,**也很簡單:
public class threadtest
});}
}}
輸出結果:
當前執行緒還沒有給threadlocal賦值,但是threadlocal裡面已經有值了。
解決辦法可以看threadlocal的api:
只要在使用threadlocal之前或者之後remove一下就好了。
ThreadLocal執行緒池例項
學習了多執行緒的理論後,下面我們來看工作中遇到的乙個具體例項。public integer startareaindex listactivityids arealist if collectionutils.isempty arealist logtypeenum.activity solr.in...
threadLocal 和 執行緒池 問題記錄
問題 在web應用中,獲取使用者的身份後,使用filter將身份資訊採用putifabsent的形式放在了 threadlocal 中。迴圈請求servlet,發現使用者身份沒有變化。解析只有當threadlocal的生命週期受限於task的生命週期時,在thread pool的thread裡使用t...
ThreadLocal與執行緒池使用的問題
感謝博主的這篇分享,見 在今天的面試中,突然被考官問了這個問題,當時脫口而出的是 threadlocal容易會有記憶體洩漏,需要注意remove。其實自己仔細想想,這個回答太過於結果了,沒有思考為何要配合執行緒池的時候,去remove。注意,這裡需要你的jdk版本為1.8及以上,否者清將lambda...