Semaphore可以用来实现服务的并发限流,以下是使用Semaphore的简单示例代码
public class SpringbootApplication {
//定义一个信号量,初始参数为6,代表只允许6个线程同时访问
final static Semaphore semaphore = new Semaphore(6);
//定义一个线程任务
static class Task implements Runnable {
@Override
public void run() {
try {
//获取许可
semaphore.acquire();
System.out.println(System.currentTimeMillis() + ":" + Thread.currentThread().getName() + "获取许可证");
//假设处理业务逻辑要3秒
TimeUnit.SECONDS.sleep(3);
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println(System.currentTimeMillis() + ":" + Thread.currentThread().getName() + "释放许可证");
//释放许可
semaphore.release();
}
}
}
用main函数测试下:
public static void main(String[] args) throws Exception {
for (int i = 0; i < 12; i++) {
new Thread(new Task(), "线程" + i).start();
}
}
}
运行结果如下:
总结
通过运行结果,可以了解到,使用Semaphore,可以起到并发限流的作用,当然了,如果把Semaphore的初始参数设置为1,那它的效果就和独占锁一样了。