這篇文章主要介紹ThreadLocal和ThreadPoolExecutor如何同時使用,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
ThreadLocal會為每個線程保存一份成員變量的副本,而ThreadPoolExecutor是一些線程不斷執行各種任務(線程復用)。比如,你讓具有3個線程的ThreadPoolExecutor執行13個任務,那么有一個線程會執行5個任務,另外兩個線程執行4個任務。那么,每個線程執行的這幾個(5個或4個)任務,會共享ThreadLocal的數據備份。并不是每個任務有一個數據副本。
來段代碼說明
TestNum類中定義sewNum這樣一個ThreadLocal量,每個線程訪問這個類時,都會有一個seqNum的副本。
定義一個任務,打印ThreadLocal變量值
在一個具有3個線程的線程池中,執行13個任務
輸出結果,可以看到每個線程,都有一份ThreadLocal的數據備份。但是這些任務并沒有獨立的數據副本(同一線程執行的任務,共享同一個副本數據)
這就是文章開頭提到的分庫BUG產生的原因。程序員產生了每個任務都有一個數據副本的錯覺。
以上是“ThreadLocal和ThreadPoolExecutor如何同時使用”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。