Semaphore就是多对多的问题,最形象的就是抢车位。多个线程抢多个资源
例:停车位,当有10个车位20辆车时。总会有10辆车没有车位。只能等一辆车走之后才能有一辆车可以停车。
package com.demo;
import java.util.concurrent.Semaphore;
import java.util.concurrent.TimeUnit;
/**
* @program: algorithm
* @description:
* @author: Mr.XYC
* @create: 2021-07-01 11:23
**/
public class SemaphoreDemo {
public static void main(String[] args) {
Semaphore semaphore = new Semaphore(3);
for (int i = 1; i <= 6; i++) {
new Thread(()->{
try {
semaphore.acquire();
System.out.println(Thread.currentThread().getName()+"抢到车位");
TimeUnit.SECONDS.sleep(3);
System.out.println(Thread.currentThread().getName()+"停车三秒后离开车位");
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
semaphore.release();
}
},String.valueOf(i)).start();
}
}
}
1抢到车位
2抢到车位
3抢到车位
3停车三秒后离开车位
2停车三秒后离开车位
1停车三秒后离开车位
4抢到车位
6抢到车位
5抢到车位
5停车三秒后离开车位
4停车三秒后离开车位
6停车三秒后离开车位