zoukankan      html  css  js  c++  java
  • 在 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。

  • 相关阅读:
    1052 Linked List Sorting (25 分)
    1051 Pop Sequence (25 分)
    1050 String Subtraction (20 分)
    1049 Counting Ones (30 分)
    1048 Find Coins (25 分)
    1047 Student List for Course (25 分)
    1046 Shortest Distance (20 分)
    1045 Favorite Color Stripe (30 分)
    1044 Shopping in Mars (25 分)
    1055 The World's Richest (25 分)
  • 原文地址:https://www.cnblogs.com/programb/p/13021105.html
Copyright © 2011-2022 走看看