Semaphore是一个同步类,也叫信号量。它可以限制访问同一资源的线程数量,也可以用于生产者-消费者模式。它底层维护着一组许可证,它通过acquire方法获取一个许可证,通过release方法释放一个许可证,如果许可证被用完,对于后面需要访问资源的线程会被阻塞,直到有许可证释放为止。
代码实现
import java.util.concurrent.Semaphore;
public class SemaphoreExample {
public static void main(String[] args) {
Semaphore semaphore = new Semaphore(2); // 创建一个Semaphore,初始许可证数量为2Runnable task = () -> {
try {
semaphore.acquire(); // 获取一个许可证
System.out.println(Thread.currentThread().getName() + " acquired a permit");
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
semaphore.release(); // 释放一个许可证
System.out.println(Thread.currentThread().getName() + " released a permit");
}
};Thread t1 = new Thread(task, "Thread 1");
Thread t2 = new Thread(task, "Thread 2");
Thread t3 = new Thread(task, "Thread 3");t1.start();
t2.start();
t3.start();
}
}