Java 线程同步总结
(1)synchronized方法
(2)synchronized塊
?
二、Lock
注意:及時釋放Lock鎖,否則會出現死鎖,通常在finally代碼釋放鎖?
(1)ReentrantLock ? ? ? ? ?
實現Lock接口,提供lock(),tryLock()和unLock()方法。
lock()? ? ? ? ? 獲取鎖
tryLock() ? ? 嘗試獲取鎖,返回true/false
unlock() ? ? ?釋放獲得的鎖
?
(2)ReentrantReadWriteLock
實現ReadWriteLock接口,并非Lock接口。
readLock()方法獲取可讀鎖對象是Lock的實例,可讀鎖對象是共享鎖
writeLock()方法獲取可寫鎖Lock對象是Lock的實例,可寫鎖對象是排他鎖
?
三、volatile關鍵字
volatile關鍵字為域變量的訪問提供了一種免鎖機制,?使用volatile修飾域相當于告訴虛擬機該域可能會被其他線程更新,?因此每次使用該域就要重新計算,而不是使用寄存器中的值。
volatile只能保證代碼的可見性,而不能保證代碼的原子性。
volatile不會提供任何原子操作,它也不能用來修飾final類型的變量 。
?
volatile關鍵字具備了兩層語義:
1)保證了不同線程對這個變量進行操作時的可見性,即一個線程修改了某個變量的值,這新值對其他線程來說是立即可見的。
2)禁止進行指令重排序。
?
使用場景:
1)對變量的寫操作不依賴于當前值,如i++
2)該變量沒有包含在具有其他變量的不變式中,如low<up
?
四、ThreadLocal類
ThreadLocal管理變量,則每一個使用該變量的線程都獲得該變量的副本,?副本之間相互獨立,這樣每一個線程都可以隨意修改自己的變量副本,而不會對其他線程產生影響。
ThreadLocal 類的常用方法
??? get() ? ? ? ? ? ? ? ? ? ? ?返回此線程局部變量的當前線程副本中的值?
??? initialValue() ? ? ? ? ?返回此線程局部變量的當前線程的初始值"
??? set(T value) ? ? ? ? ?將此線程局部變量的當前線程副本中的值設置為value
?
五、使用阻塞隊列實現線程同步
BlockingQueue接口和BlockingDeque,使用ReentrantLock
ArrayBlockingQueue
LinkedBlockingQueue
LinkedBlockingDeque
SynchronousQueue
阻塞方法put、take
非阻塞方法offer與poll、add與remove
?
六、原子變量實現線程同步
?java.util.concurrent.atomic包
(1)使用volatile和CAS算法
AtomicBoolean
AtomicInteger
AtomicIntegerArray
AtomicLong
AtomicLongArray
AtomicReference
AtomicReferenceArray
AtomicStampedReference
?(2)使用Striped64和Cell(volatile和CAS)
LongAccumulator
LongAdder
DoubleAccumulator
DoubleAdder
?
七、wait與notify()/notifyAll()
?Object類的成員方法,在同步代碼區使用
wait ? ? ? ? 阻塞線程
notify ? ? ? 喚醒阻塞線程
notifyAll ? 喚醒所有阻塞線程
?
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的Java 线程同步总结的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 怎样才能知道显卡或CPU是否与主板兼容?
- 下一篇: Java 类加载总结