溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ThreadLocal和ThreadPoolExecutor如何同時使用

發布時間:2021-12-04 09:56:30 來源:億速云 閱讀:186 作者:小新 欄目:大數據

這篇文章主要介紹ThreadLocal和ThreadPoolExecutor如何同時使用,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

ThreadLocal會為每個線程保存一份成員變量的副本,而ThreadPoolExecutor是一些線程不斷執行各種任務(線程復用)。比如,你讓具有3個線程的ThreadPoolExecutor執行13個任務,那么有一個線程會執行5個任務,另外兩個線程執行4個任務。那么,每個線程執行的這幾個(5個或4個)任務,會共享ThreadLocal的數據備份。并不是每個任務有一個數據副本。

來段代碼說明

TestNum類中定義sewNum這樣一個ThreadLocal量,每個線程訪問這個類時,都會有一個seqNum的副本。

ThreadLocal和ThreadPoolExecutor如何同時使用

定義一個任務,打印ThreadLocal變量值

ThreadLocal和ThreadPoolExecutor如何同時使用

在一個具有3個線程的線程池中,執行13個任務

ThreadLocal和ThreadPoolExecutor如何同時使用

輸出結果,可以看到每個線程,都有一份ThreadLocal的數據備份。但是這些任務并沒有獨立的數據副本(同一線程執行的任務,共享同一個副本數據)

ThreadLocal和ThreadPoolExecutor如何同時使用

這就是文章開頭提到的分庫BUG產生的原因。程序員產生了每個任務都有一個數據副本的錯覺。

以上是“ThreadLocal和ThreadPoolExecutor如何同時使用”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女