Semaphore的作用
Semaphore限流:用于控制某一时刻的并发线程数 和 一个资源供多个线程的互斥使用。
初始化new Semaphore(int n),n表示在某时刻最大接收的线程数
在线程内部调用semaphore.acquire(),表示该线程被执行,此时信号数减1,
当该线程执行完毕时调用semaphore.release(),信号量再加1。
模拟就餐等待,某餐饮店5个餐位,某时刻来了10组客人
import java.util.concurrent.Semaphore;
public class SemaphoreDemo {
public static void main(String[] args) {
// 设置同一时刻最大并发数为5
Semaphore semaphore = new Semaphore(5);
// 创建10个线程,观看10个线程是否同一时刻最多只能并发5个线程
for(int i = 0; i < 10; i++) {
new Thread(() -> {
try {
// 信号量接收当前线程
semaphore.acquire();
// 业务代码
System.out.println(Thread.currentThread().getName() + " 开始就餐");
try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); }
System.out.println(Thread.currentThread().getName() + " 3秒后离开餐饮店");
// 信号量释放当前线程
semaphore.release();
} catch (InterruptedException e) {e.printStackTrace();}
}, String.valueOf(i)).start();
}
}
}
模拟结果和解析如下
从运行可知0-5号线程运行之后,其他线程不能运行,等有人离开执行完毕时,其他线程才能补上空闲的餐位继续执行