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