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