基于白嫖B站黑马程序员视频:全面深入学习java并发编程,java基础进阶中级必会教程
1 场景
本意,信号量,用来限制能够同时访问共享资源(可以多个)的线程上限。
2 例子
public class Main {
public static void main(String[] args) {
//创建semaphore对象
Semaphore semaphore = new Semaphore(3);
//模型运行十个线程
for (int i = 0; i < 10; i++) {
int j = i;
new Thread(() -> {
//加上信号量
try {
semaphore.acquire();
} catch (InterruptedException e) {
e.printStackTrace();
}
//执行逻辑
try {
Thread.sleep(1000);
System.out.println("执行线程:" + j);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
semaphore.release();//释放信号量
}
}).start();
}
}
}
运行可以看到基本上3个一起运行,没有获得计算资源的处于阻塞状态;
3 解释说明
- 可以用来限流,只适合单机限流,并且限制的是线程数,不是资源数;
- 适用于资源数和线程数匹配一致的情况;
4 原理
更像是一个停车场,permits是车位,当线程获得了资源,就permits-1;
使用的底层依然是AQS,state就是permits;
注意:Semaphore逻辑是同时允许多少线程同时进行,当Semaphore(1)时,可以理解为互斥锁;