java并发之线程封闭(二)
轉載自?https://blog.csdn.net/maosijunzi/article/details/18561107
線程封閉
實現好的并發是一件困難的事情,所以很多時候我們都想躲避并發。避免并發最簡單的方法就是線程封閉。什么是線程封閉呢?
就是把對象封裝到一個線程里,只有這一個線程能看到此對象。那么這個對象就算不是線程安全的也不會出現任何安全問題。實現線程封閉有哪些方法呢?
1:ad-hoc線程封閉
?????????這是完全靠實現者控制的線程封閉,他的線程封閉完全靠實現者實現。也是最糟糕的一種線程封閉。所以我們直接把他忽略掉吧。
2:棧封閉
????????棧封閉是我們編程當中遇到的最多的線程封閉。什么是棧封閉呢?簡單的說就是局部變量。多個線程訪問一個方法,此方法中的
局部變量都會被拷貝一分兒到線程棧中。所以局部變量是不被多個線程所共享的,也就不會出現并發問題。所以能用局部變量就別用全局的變量,全局變量容易引起并發問題。
3:ThreadLocal封閉
????? 使用ThreadLocal是實現線程封閉的最好方法,有興趣的朋友可以研究一下ThreadLocal的源碼,其實ThreadLocal內部維護了一個Map,Map的key是每個線程的名稱,而Map的值就是我們要封閉的對象。每個線程中的對象都對應著Map中一個值,也就是ThreadLocal利用Map實現了對象的線程封閉。這里就不說ThreadLocal的使用方法了,度娘一下便知。
?
總之,當我們要用線程封閉來避免并發問題的時候,最好使用的就是 【棧封閉】 和 【ThreadLocal】。
超強干貨來襲 云風專訪:近40年碼齡,通宵達旦的技術人生
總結
以上是生活随笔為你收集整理的java并发之线程封闭(二)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java中产生死锁的原因及如何避免
- 下一篇: redis基本类型以及优点特性