计数信号量用来控制同时访问某个特定资源的操作数量,或者同时执行某个指定操作的数量。计数信号量还可以用来实现某种资源池,或者对容器施加边界。
/**
* @description: 可设置边界容量的阻塞容器
* @create: 2018-12-15 16:51
**/
public class BoundeHashSet<T> {
private final Set<T> set;
private final Semaphore semaphore;
public BoundeHashSet(int semaphore){
this.semaphore = new Semaphore(semaphore);
set = Collections.synchronizedSet(new HashSet<>());
}
public boolean add(T o) throws InterruptedException {
//获取许可,若没有剩余信号量许可,将一直阻塞
semaphore.acquire();
boolean wasAdded = false;
try {
wasAdded = set.add(o);
return wasAdded;
}
finally {
if (!wasAdded){
semaphore.release();
}
}
}
public boolean remove(Object o){
boolean wasRemoved = set.remove(o);
if (wasRemoved){
semaphore.release();
}
return wasRemoved;
}
}
本文介绍计数信号量的基本概念及其在控制资源访问中的应用,通过一个具体的阻塞容器实例,展示了如何使用计数信号量实现资源池的边界控制。该容器通过获取信号量许可来限制同时存取元素的数量,确保了系统的稳定性和资源的有效利用。
9230

被折叠的 条评论
为什么被折叠?



