• 在 Java 中 CycliBarriar 和 CountdownLatch 有什么区别?


    CyclicBarrier 可以重复使用,而 CountdownLatch 不能重复使用。

    Java 的 concurrent 包里面的 CountDownLatch 其实可以把它看作一个计数器,

    只不过这个计数器的操作是原子操作,同时只能有一个线程去操作这个计数器,

    也就是同时只能有一个线程去减这个计数器里面的值。

    你可以向 CountDownLatch 对象设置一个初始的数字作为计数值,任何调用这个

    对象上的 await()方法都会阻塞,直到这个计数器的计数值被其他的线程减为 0 为

    止。

    所以在当前计数到达零之前,await 方法会一直受阻塞。之后,会释放所有等待

    的线程,await 的所有后续调用都将立即返回。这种现象只出现一次——计数无法

    被重置。如果需要重置计数,请考虑使用 CyclicBarrier。

    CountDownLatch 的一个非常典型的应用场景是:有一个任务想要往下执行,但

    必须要等到其他的任务执行完毕后才可以继续往下执行。假如我们这个想要继续

    往下执行的任务调用一个 CountDownLatch 对象的 await()方法,其他的任务执

    行完自己的任务后调用同一个 CountDownLatch 对象上的 countDown()方法,

    这个调用 await()方法的任务将一直阻塞等待,直到这个 CountDownLatch 对象

    的计数值减到 0 为止。

    CyclicBarrier 一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏

    障点 (common barrier point)。在涉及一组固定大小的线程的程序中,这些线程

    必须不时地互相等待,此时 CyclicBarrier 很有用。因为该 barrier 在释放等待

    线程后可以重用,所以称它为循环 barrier。

  • 相关阅读:
    MySQL创建用户及用户授权
    kubectl 更新容器镜像
    harbor安装报权限错误问题解决
    docker拉取harbor仓库镜像报x509: certificate signed by unknown authority的解决方案
    pkexec提权(限制条件:用户必须在sudo组里且知道用户密码)
    sudo useradd提权
    Linux下绕过空格的方式总结
    Solved: cannot kill Docker container permission denied
    nginx和Docker的打怪升级
    三种免费Terminal工具推荐
  • 原文地址:https://www.cnblogs.com/programb/p/13021105.html
Copyright © 2020-2023  润新知