简单了解下Semaphore的使用

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,那它的效果就和独占锁一样了。

原创文章 358 获赞 387 访问量 7万+

猜你喜欢

转载自blog.csdn.net/weixin_38106322/article/details/105699866
今日推荐