• Java 多线程同步妙招 -- CountDownLatch计数器


    CountDownLatch类位于java.util.concurrent包下,利用它可以实现类似计数器的功能。比如有一个任务A,它要等待其他n个批量任务执行完毕之后才能执行,此时就可以利用CountDownLatch来实现这种功能了。

    比如我们要监控所有上游系统的状态,于是可以用一个线程池去跑每个上游系统的健康状态,等他们全部跑完我们才能返回所有系统的检测结果,这是后就可以在初始化线程池的时候也初始化一个CountDownLatch,CountDownLatch的初始化数值就是所有上游系统的数量,然后在每一个线程的run方法里面加一个 countDownLatch.countDown(); 意思是计数器减一个。然后在汇总的地方加一个 countDownLatch.await(); 意思是等待计数器减至0 (即所有线程跑完),然后进行汇总。

    综上,CountDownLatch的一般使用方式就三步:初始化计数器(count = n),计数器-1 (n - 1),等待计数器到0 (n = 0)

    CountDownLatch的重要方法:

    public void await() throws InterruptedException { };   //调用await()方法的线程会被挂起,它会等待直到count值为0才继续执行

    public boolean await(long timeout, TimeUnit unit) throws InterruptedException { };  //和await()类似,只不过等待一定的时间后count值还没变为0的话就会继续执行

    public void countDown() { };  //将count值减1

    代码示例:

    List<SupportedVehicle> vehicles = getVehicles();
    CountDownLatch countDownLatch = new CountDownLatch(vehicles.size());
    for (SupportedVehicle vehicle : vehicles) {
        pool.execute(new Runnable() {
            @Override
            public void run() {
                handleVehicle(vehicle);
                countDownLatch.countDown();
            }
        });
    }
    countDownLatch.await();
    System.out.println(vehicles);
  • 相关阅读:
    Day4-装饰器
    Day3-递归函数、高阶函数、匿名函数
    Day3-函数及作用域
    Day2-字符编码转换
    Day2-文件操作
    Day2-列表、字符串、字典、集合
    Day1-模块初识
    JavaScript 笔试题
    从JavaScript 数组去重谈性能优化
    prototype
  • 原文地址:https://www.cnblogs.com/cnsec/p/13407171.html
Copyright © 2020-2023  润新知