java并發(fā)編程專題(六)----淺析(JUC)Semaphore
半路開始看的朋友可以回顧一下前幾篇
java并發(fā)編程專題(一)----線程基礎(chǔ)知識(shí)
java并發(fā)編程專題(二)----如何創(chuàng)建并運(yùn)行java線程
Semaphore,從字面意義上我們知道他是信號(hào)量的意思。在java中,一個(gè)計(jì)數(shù)信號(hào)量維護(hù)了一個(gè)許可集。Semaphore 只對(duì)可用許可的號(hào)碼進(jìn)行計(jì)數(shù),并采取相應(yīng)的行動(dòng)。拿到信號(hào)量的線程可以進(jìn)入代碼,否則就等待。通過acquire()和release()獲取和釋放訪問許可。
信號(hào)量Semaphore是一個(gè)控制訪問多個(gè)共享資源的計(jì)數(shù)器,它本質(zhì)上是一個(gè)“共享鎖”。
Java并發(fā)提供了兩種加鎖模式:共享鎖和獨(dú)占鎖。前面介紹的ReentrantLock就是獨(dú)占鎖。對(duì)于獨(dú)占鎖而言,它每次只能有一個(gè)線程持有,而共享鎖則不同,它允許多個(gè)線程并行持有鎖,并發(fā)訪問共享資源。
獨(dú)占鎖它所采用的是一種悲觀的加鎖策略, 對(duì)于寫而言為了避免沖突獨(dú)占是必須的,但是對(duì)于讀就沒有必要了,因?yàn)樗粫?huì)影響數(shù)據(jù)的一致性。如果某個(gè)只讀線程獲取獨(dú)占鎖,則其他讀線程都只能等待了,這種情況下就限制了不必要的并發(fā)性,降低了吞吐量。而共享鎖則不同,它放寬了加鎖的條件,采用了樂觀鎖機(jī)制,它是允許多個(gè)讀線程同時(shí)訪問同一個(gè)共享資源的。
舉一個(gè)生活中的例子,有一條單行道路口有一紅綠燈在正常的綠燈時(shí)間內(nèi)如果騎車速度都很平均只能過去20輛車,這就意味著排在前面的20輛肯定能過去紅綠燈,后面的就只能等下一個(gè)綠燈了。但是如果這個(gè)時(shí)候有車不想過去這個(gè)路口它駛向了邊上別的路,那么后面的車就有機(jī)會(huì)。下面我們來看一個(gè)簡單的例子:
public class TestSemaphore {
public static void main(String[] args) {
final Semaphore semaphore = new Semaphore(5);
ExecutorService executorService = Executors.newCachedThreadPool();
for(int i = 0;i<10;i++){
int j = 0;
executorService.submit(new A("car"+(j++),semaphore),"Thread"+(j++));
//new Thread(new A("car"+(j++),semaphore),"Thread"+(j++)).start();
if(i == 5){
try {
Thread.sleep(1000);
System.out.println("最后還有"+semaphore.availablePermits()+"個(gè)許可可用");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
System.out.println("最后還有"+semaphore.availablePermits()+"個(gè)許可可用");
}
}
class A implements Runnable{
String carName;
private Semaphore semaphore;
public A(String carName, Semaphore semaphore){
this.carName = carName;
this.semaphore = semaphore;
}
public void getWay(){
System.out.println("this car is get the way" + Thread.currentThread().getName());
}
public void run() {
try {
if(semaphore.availablePermits() > 0){
semaphore.acquire();
getWay();
semaphore.release();
}else{
System.out.println("請等待========");
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
以上就是java并發(fā)編程專題(六)----淺析(JUC)Semaphore的詳細(xì)內(nèi)容,更多關(guān)于JAVA Semaphore的資料請關(guān)注腳本之家其它相關(guān)文章!
- java并發(fā)編程專題(八)----(JUC)實(shí)例講解CountDownLatch
- java并發(fā)編程工具類JUC之LinkedBlockingQueue鏈表隊(duì)列
- java并發(fā)編程專題(十)----(JUC原子類)基本類型詳解
- java并發(fā)編程專題(九)----(JUC)淺析CyclicBarrier
- java并發(fā)編程專題(七)----(JUC)ReadWriteLock的用法
- java并發(fā)編程專題(五)----詳解(JUC)ReentrantLock
- java并發(fā)編程專題(四)----淺談(JUC)Lock鎖
- java并發(fā)編程JUC CountDownLatch線程同步
相關(guān)文章
Java設(shè)計(jì)模式之享元模式(Flyweight Pattern)詳解
享元模式(Flyweight Pattern)是一種結(jié)構(gòu)型設(shè)計(jì)模式,旨在減少對(duì)象的數(shù)量,以節(jié)省內(nèi)存空間和提高性能,本文將詳細(xì)的給大家介紹一下Java享元模式,需要的朋友可以參考下2023-07-07
springboot解決Class path contains multiple 
這篇文章主要介紹了springboot解決Class path contains multiple SLF4J bindings問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
Java如何使用正則表達(dá)式從字符串中提取數(shù)字
這篇文章主要介紹了Java如何使用正則表達(dá)式從字符串中提取數(shù)字問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12
Java詳解實(shí)現(xiàn)多線程的四種方式總結(jié)
哈哈!經(jīng)過一個(gè)階段的學(xué)習(xí),Java基礎(chǔ)知識(shí)學(xué)習(xí)終于到多線程了!Java多線程以及后面互斥鎖的概念都是Java基礎(chǔ)學(xué)習(xí)的難點(diǎn),所以我做了一個(gè)總結(jié),希望對(duì)大家也有幫助2022-07-07
SpringBoot使用工具類實(shí)現(xiàn)獲取容器中的Bean
這篇文章主要為大家詳細(xì)介紹了SpringBoot如何使用工具類實(shí)現(xiàn)獲取容器中的Bean,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03
Springboot實(shí)現(xiàn)添加本地模塊依賴方式
這篇文章主要介紹了Springboot實(shí)現(xiàn)添加本地模塊依賴方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02

