Semaphore 是一个计数信号量,必须由获取它的线程释放。
常用于限制可以访问某些资源的线程数量,例如通过 Semaphore 限流。
Semaphore 只有3个操作:
初始化
增加
减少
Demo : 模拟停车 ,只有三个车位,走一个才能来一个
public class SemaphoreTest {
public static void main(String[] args) {
Semaphore semaphore = new Semaphore(3); // 设置三个车位
for (int i = 1; i <=6 ; i++) { // 六辆车要停车
new Thread(() -> {
try {
semaphore.acquire(); // 抢占 -1 操作
System.out.println(Thread.currentThread().getName() + " \t 抢到车位");
TimeUnit.SECONDS.sleep(3); // 停3秒
System.out.println(Thread.currentThread().getName() + "\t 离开");
} catch (Exception e) {
e.printStackTrace();
} finally {
semaphore.release(); // 释放 释放后 +1
}
},String.valueOf(i)).start();
}
}
}
-- 运行结果
3 抢到车位
2 抢到车位
4 抢到车位
3 离开
2 离开
4 离开
1 抢到车位
5 抢到车位
6 抢到车位
1 离开
5 离开
6 离开