Java基于Semaphore構(gòu)建阻塞對(duì)象池
java中使用Semaphore構(gòu)建阻塞對(duì)象池
Semaphore是java 5中引入的概念,叫做計(jì)數(shù)信號(hào)量。主要用來(lái)控制同時(shí)訪問(wèn)某個(gè)特定資源的訪問(wèn)數(shù)量或者執(zhí)行某個(gè)操作的數(shù)量。
Semaphore中定義了一組虛擬的permits,通過(guò)獲取和釋放這些permits,Semaphore可以控制資源的個(gè)數(shù)。
Semaphore的這個(gè)特性可以用來(lái)構(gòu)造資源池,比如數(shù)據(jù)庫(kù)連接池等。
Semaphore有兩個(gè)構(gòu)造函數(shù):
public Semaphore(int permits) { sync = new NonfairSync(permits); } public Semaphore(int permits, boolean fair) { sync = fair ? new FairSync(permits) : new NonfairSync(permits); }
permits定義了許可資源的個(gè)數(shù),而fair則表示是否支持FIFO的順序。
兩個(gè)比較常用的方法就是acquire和release了。
public void acquire() throws InterruptedException { sync.acquireSharedInterruptibly(1); } public void release() { sync.releaseShared(1); }
其中acquire用來(lái)獲取資源,release用來(lái)釋放資源。
有了這兩個(gè)特性, 我們看一下怎么使用Semaphore來(lái)定義一個(gè)一個(gè)有界容器。
我們可以將Semaphore初始化為容器池大小,并且在容器池獲取資源時(shí)調(diào)用acquire,將資源返回給容器池之后再調(diào)用release。
我們看下面的一個(gè)實(shí)現(xiàn):
public class SemaphoreUsage<T> { private final Set<T> set; private final Semaphore sem; public SemaphoreUsage(int bound){ this.set = Collections.synchronizedSet(new HashSet<T>()); sem= new Semaphore(bound); } public boolean add (T o) throws InterruptedException{ sem.acquire(); boolean wasAdded = false; try{ wasAdded=set.add(o); return wasAdded; }finally { if(!wasAdded){ sem.release(); } } } public boolean remove(Object o){ boolean wasRemoved = set.remove(o); if(wasRemoved){ sem.release(); } return wasRemoved; } }
上面的例子我們定義了一個(gè)有界的synchronizedSet。 要注意一點(diǎn)是在add方法中,只有add成功之后才會(huì)調(diào)用release方法。
本文的例子請(qǐng)參考https://github.com/ddean2009/learn-java-concurrency/tree/master/Semaphore
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Java并發(fā)編程Semaphore計(jì)數(shù)信號(hào)量詳解
- Java并發(fā)編程之Semaphore(信號(hào)量)詳解及實(shí)例
- Java信號(hào)量Semaphore原理及代碼實(shí)例
- Java 信號(hào)量Semaphore的實(shí)現(xiàn)
- Java中Semaphore(信號(hào)量)的使用方法
- Java并發(fā)系列之Semaphore源碼分析
- Java并發(fā)編程:CountDownLatch與CyclicBarrier和Semaphore的實(shí)例詳解
- JAVA 多線程之信號(hào)量(Semaphore)實(shí)例詳解
- java線程并發(fā)semaphore類示例
- 分析Java并發(fā)編程之信號(hào)量Semaphore
相關(guān)文章
8種常見(jiàn)的接口請(qǐng)求重試方法總結(jié)
在跨境業(yè)務(wù)中,可能第三方的服務(wù)器分布在世界的各個(gè)角落,所以請(qǐng)求三方接口的時(shí)候,難免會(huì)遇到一些網(wǎng)絡(luò)問(wèn)題,這時(shí)候需要加入重試機(jī)制了,下面小編就給大家分享幾個(gè)接口重試的寫(xiě)法吧2023-11-11詳解IntelliJ IDEA 中如何配置多個(gè)jdk版本即(1.7和1.8兩個(gè)jdk都可用)
這篇文章主要介紹了詳解IntelliJ IDEA 中如何配置多個(gè)jdk版本即(1.7和1.8兩個(gè)jdk都可用),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-11-11Springboot如何實(shí)現(xiàn)對(duì)配置文件中的明文密碼加密
這篇文章主要介紹了Springboot如何實(shí)現(xiàn)對(duì)配置文件中的明文密碼加密問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12SpringBoot集成JWT實(shí)現(xiàn)登陸驗(yàn)證的方法詳解
JSON?Web?Token(JWT)是一個(gè)開(kāi)放的標(biāo)準(zhǔn)(RFC?7519),它定義了一個(gè)緊湊且自包含的方式,用于在各方之間以JSON對(duì)象安全地傳輸信息。本文將利用SpringBoot集成JWT實(shí)現(xiàn)登陸驗(yàn)證,感興趣的可以了解一下2022-05-05