线程本地ThreadLocal的介绍与使用!
ThreadLocal簡介
我們通過上兩篇的學習,我們已經知道了變量值的共享可以使用public static變量的形式,所有的線程都使用同一個被public static修飾的變量。
那么如果我們想實現每一個線程都有自己的共享變量該如何解決哪?JDK提供的ThreadLocal正是為了解決這樣的問題的。
類ThreadLocal主要解決的就是每個線程綁定自己的值,可以將ThreadLocal類比喻成全局存放數據的盒子,盒子中可以存儲每個線程的私有變量。
先舉個栗子
示例代碼如下:
運行結果:
可以看出雖然多個線程對同一個變量進行訪問,但是由于threadLocal變量由ThreadLocal 修飾,則不同的線程訪問的就是該線程設置的值,這里也就體現出來ThreadLocal的作用。
當使用ThreadLocal維護變量時,ThreadLocal為每個使用該變量的線程提供獨立的變量副本,所以每一個線程都可以獨立地改變自己的副本,而不會影響其它線程所對應的副本。
ThreadLocal與synchronized同步機制的比較
在同步機制中,通過對象的鎖機制保證同一時間只有一個線程訪問變量。這時該變量是多個線程共享的,使用同步機制要求程序慎密地分析什么時候對變量進行讀寫,什么時候需要鎖定某個對象,什么時候釋放對象鎖等繁雜的問題,程序設計和編寫難度相對較大。
ThreadLocal是線程局部變量,是一種多線程間并發訪問變量的解決方案。和synchronized等加鎖的方式不同,ThreadLocal完全不提供鎖,而使用以空間換時間的方式,為每個線程提供變量的獨立副本,以保證線程的安全。
本文來自千鋒教育,轉載請注明出處。
總結
以上是生活随笔為你收集整理的线程本地ThreadLocal的介绍与使用!的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 怎样使用Spring Boot项目的单元
- 下一篇: 类操作是什么意思?jQuery的类操作教