package study.java.thread.Semaphore;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Semaphore;
public class TestSemaphore{
public static void main(String[] args) {
//采用新特性来启动和管理线程——内部使用线程池
ExecutorService exec = Executors.newCachedThreadPool();
//只允许5个线程同时访问
final Semaphore semp = new Semaphore(5);
//模拟10个客户端访问
for (int index = 0; index < 10; index++){
final int num = index;
Runnable run = new Runnable() {
public void run() {
try {
//获取许可
semp.acquire();
System.out.println("线程" +
Thread.currentThread().getName() + "获得许可:" + num);
//模拟耗时的任务
Thread.sleep(10000);
//释放许可
semp.release();
System.out.println("线程" +
Thread.currentThread().getName() + "释放许可:" + num);
System.out.println("当前允许进入的任务个数:" +
semp.availablePermits());
}catch(InterruptedException e){
e.printStackTrace();
}
}
};
exec.execute(run);
}
//关闭线程池
exec.shutdown();
}
}