一. AQS資源共享方式
AQS有兩種資源共享方式:Exclusive(獨占)和Share(共享)。
1. Exclusive(獨占)
只有一個線程能執(zhí)行,如ReentrantLock,可分為公平鎖和非公平鎖:
公平鎖:按照線程在隊列中的排隊順序,先到者先拿到鎖
非公平鎖:當線程要獲取鎖時,無視隊列順序直接去搶鎖,誰搶到就是誰的
2. Share(共享)
多個線程可同時執(zhí)行,如Semaphore/CountDownLatch。Semaphore、CountDownLatch、 CyclicBarrier、ReadWriteLock 我們都會在后面講到。
ReentrantReadWriteLock 可以看成是組合式,因為ReentrantReadWriteLock也就是讀寫鎖允許多個線程同時對某一資源進行讀。
不同的自定義同步器爭用共享資源的方式也不同。自定義同步器在實現(xiàn)時只需要實現(xiàn)共享資源 state 的獲取與釋放方式即可,至于具體線程等待隊列的維護(如獲取資源失敗入隊/喚醒出隊等),AQS已經(jīng)在頂層實現(xiàn)好了。
二. 如何讓 Java 的線程彼此同步?
主要是利用如下技術(shù):
synchronized
volatile
ReenreantLock
使用局部變量實現(xiàn)線程同步
三. 你了解過哪些同步器?請分別介紹下
1. Semaphore同步器
特征:
經(jīng)典的信號量,通過計數(shù)器控制對共享資源的訪問
Semaphore(int count):創(chuàng)建擁有count個許可證的信號量
acquire()/acquire(int num) : 獲取1/num個許可證
release/release(int num) : 釋放1/num個許可證
2. CountDownLatch同步器
特征:
必須發(fā)生指定數(shù)量的事件后才可以繼續(xù)運行(比如賽跑比賽,裁判喊出3,2,1之后大家才同時跑)
CountDownLatch(int count):必須發(fā)生count個數(shù)量才可以打開鎖存器
await:等待鎖存器
countDown:觸發(fā)事件
3. CyclicBarrier同步器
特征:
適用于只有多個線程都到達預(yù)定點時才可以繼續(xù)執(zhí)行(比如斗地主,需要等齊三個人才開始)
CyclicBarrier(int num) :等待線程的數(shù)量
CyclicBarrier(int num, Runnable action) :等待線程的數(shù)量以及所有線程到達后的操作
await() : 到達臨界點后暫停線程
4. 交換器(Exchanger)同步器
5. Phaser同步器
更多關(guān)于“Java培訓(xùn)”的問題,歡迎咨詢千鋒教育在線名師。千鋒已有十余年的培訓(xùn)經(jīng)驗,課程大綱更科學(xué)更專業(yè),有針對零基礎(chǔ)的就業(yè)班,有針對想提升技術(shù)的好程序員班,高品質(zhì)課程助力你實現(xiàn)java程序員夢想。