CountDownLatch是减计数方式,计数==0时释放所有等待的线程;CyclicBarrier是加计数方式,计数达到构造方法中参数指定的值时释放所有等待的线程。
CountDownLatch当计数到0时,计数无法被重置;CyclicBarrier计数达到指定值时,计数置为0重新开始。
CountDownLatch每次调用countDown()方法计数减一,调用await()方法只进行阻塞,对计数没任何影响;CyclicBarrier只有一个await()方法,调用await()方法计数加1,若加1后的值不等于构造方法的值,则线程阻塞。

  1. import java.util.concurrent.CountDownLatch;
  2. public class TestConcurrent extends Thread {
  3. /**
  4. * CountDownLatch 是并发包中提供的一个可用于控制多个线程同时开始某个动作的类,其
  5. * 采用的方式为减计数的方式,当计数减至零时位于latch.await()后的代码才会被执行。
  6. */
  7. private static CountDownLatch latch = new CountDownLatch(10);
  8. public static void main(String[] args) {
  9. long start = System.currentTimeMillis();
  10. int i = 0;
  11. while (i < 10) {
  12. i++;
  13. new TestConcurrent().start();
  14. }
  15. try {
  16. latch.await();
  17. } catch (InterruptedException e) {
  18. e.printStackTrace();
  19. }
  20. System.out.println("use time:" + (System.currentTimeMillis() - start));
  21. }
  22. public void run() {
  23. System.out.println("...");
  24. try {
  25. Thread.sleep(100);
  26. } catch (InterruptedException e) {
  27. e.printStackTrace();
  28. }
  29. latch.countDown();
  30. }
  31. }
import java.util.concurrent.CountDownLatch;

public class TestConcurrent extends Thread {
/**
* CountDownLatch 是并发包中提供的一个可用于控制多个线程同时开始某个动作的类,其
* 采用的方式为减计数的方式,当计数减至零时位于latch.await()后的代码才会被执行。
*/
private static CountDownLatch latch = new CountDownLatch(10); public static void main(String[] args) {
long start = System.currentTimeMillis();
int i = 0;
while (i < 10) {
i++;
new TestConcurrent().start();
}
try {
latch.await();
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("use time:" + (System.currentTimeMillis() - start));
} public void run() {
System.out.println("...");
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
latch.countDown();
}
}
    1. import java.util.concurrent.BrokenBarrierException;
    2. import java.util.concurrent.CyclicBarrier;
    3. import java.util.concurrent.TimeUnit;
    4. import java.util.concurrent.TimeoutException;
    5. public class TestCyclicBarrier extends Thread {
    6. /**
    7. * CyclicBarrier 和CountDownLatch不同,CyclicBarrier是当await 的数量达到了设置的数量后,
    8. * 才继续往下执行
    9. */
    10. static CyclicBarrier cyclicBarrier = new CyclicBarrier(10);
    11. private int id;
    12. public TestCyclicBarrier(int id) {
    13. this.id = id;
    14. }
    15. public static void main(String[] args) {
    16. long start = System.currentTimeMillis();
    17. int i = 0;
    18. while (i < 10) {
    19. i++;
    20. new TestCyclicBarrier(i).start();
    21. }
    22. System.out.println("use time:" + (System.currentTimeMillis() - start));
    23. }
    24. public void run() {
    25. try {
    26. System.out.println("----start:" + id);
    27. cyclicBarrier.await(1000, TimeUnit.MILLISECONDS);
    28. System.out.println("----start__:" + id);
    29. } catch (InterruptedException e1) {
    30. e1.printStackTrace();
    31. } catch (BrokenBarrierException e) {
    32. e.printStackTrace();
    33. } catch (TimeoutException e) {
    34. e.printStackTrace();
    35. }
    36. try {
    37. Thread.sleep(100);
    38. } catch (InterruptedException e) {
    39. e.printStackTrace();
    40. }
    41. System.out.println("----end:" + id);
    42. }
    43. }

CountDownLatch和CyclicBarrier 的用法的更多相关文章

  1. CountDownLatch和CyclicBarrier区别及用法的demo

    javadoc里面的描述是这样的. CountDownLatch: A synchronization aid that allows one or more threads to wait unti ...

  2. 温故知新-多线程-forkjoin、CountDownLatch、CyclicBarrier、Semaphore用法

    Posted by 微博@Yangsc_o 原创文章,版权声明:自由转载-非商用-非衍生-保持署名 | Creative Commons BY-NC-ND 3.0 文章目录 摘要 forkjoin C ...

  3. Java并发编程:CountDownLatch、CyclicBarrier和Semaphore

    Java并发编程:CountDownLatch.CyclicBarrier和Semaphore 在java 1.5中,提供了一些非常有用的辅助类来帮助我们进行并发编程,比如CountDownLatch ...

  4. Java并发(8):CountDownLatch、CyclicBarrier、Semaphore、Callable、Future

    CountDownLatch.CyclicBarrier.Semaphore.Callable.Future  都位于java.util.concurrent包下,其中CountDownLatch.C ...

  5. CountDownLatch、CyclicBarrier和Semaphore

    转载:http://www.cnblogs.com/dolphin0520/p/3920397.html 在java 1.5中,提供了一些非常有用的辅助类来帮助我们进行并发编程,比如CountDown ...

  6. 使用Java辅助类(CountDownLatch、CyclicBarrier、Semaphore)并发编程

    在java 1.5中,提供了一些非常有用的辅助类来帮助我们进行并发编程,比如CountDownLatch,CyclicBarrier和Semaphore,今天我们就来学习一下这三个辅助类的用法 一.C ...

  7. CountDownLatch 和 CyclicBarrier 的运用及实现原理

    I.CountDownLatch 和 CyclicBarrier 的运用 CountDownlatch: 定义: 其是一个线程同步的辅助工具,通过它可以做到使一条线程一直阻塞等待,直到其他线程完成其所 ...

  8. Java并发之CountDownLatch、CyclicBarrier和Semaphore

    CountDownLatch 是能使一组线程等另一组线程都跑完了再继续跑:CyclicBarrier 能够使一组线程在一个时间点上达到同步,可以是一起开始执行全部任务或者一部分任务. CountDow ...

  9. Thread.join(), CountDownLatch、CyclicBarrier和 Semaphore区别,联系及应用

    在java 1.5中,提供了一些非常有用的辅助类来帮助我们进行并发编程,比如CountDownLatch,CyclicBarrier和Semaphore,今天我们就来学习一下这三个辅助类的用法, 由于 ...

随机推荐

  1. Android开发出现 StackOverflowError

    问题:StackOverflowError 在HTC或者摩托罗拉的手机上测试出现 StackOverflowError 的错误. 06-12 10:28:31.750: E/AndroidRuntim ...

  2. 2018.3.16 win 关闭自动更新代码

    新建一个文本文件修改后缀名为 .bat 格式 net stop wuauserv sc config wuauserv start=disabled shutdown -r -t 1

  3. Dede技巧

    解决DEDE图集上传图片时跳出302错误   本地上传图集的时候突然提示网页出错,还爆出302错误. 解决办法是在include/userlogin.class.php文件中的第二行session_s ...

  4. C/C++基础知识:函数指针和指针函数的基本概念

    [函数指针] 在程序运行中,函数代码是程序的算法指令部分,它们和数组一样也占用存储空间,都有相应的地址.可以使用指针变量指向数组的首地址,也可以使用指针变量指向函数代码的首地址,指向函数代码首地址的指 ...

  5. [vijos]P1514 天才的记忆

    背景 神仙飞啊飞 描述 从前有个人名叫W and N and B,他有着天才般的记忆力,他珍藏了许多许多的宝藏.在他离世之后留给后人一个难题(专门考验记忆力的啊!),如果谁能轻松回答出这个问题,便可以 ...

  6. Eclipse使用Mybatis-Generator插件

    Mybatis-Generator插件极大地方便了我们的开发效率,不用每张表每个字段人工去敲,所以本文介绍使用Mybatis-Generator自动生成Dao.Model.Mapping相关文件 版权 ...

  7. Install GStreamer on Ubuntu

    apt-get install libgstreamer1.0-0 gstreamer1.0-plugins-base gstreamer1.0-plugins-good gstreamer1.0-p ...

  8. 使用 Python 编写登陆接口

    # 使用 Python 编写登陆接口# Create Date: 2017.10.31 Tuesday# Author: Eric Zhao# -*- coding:utf-8 -*-'''编写登陆接 ...

  9. asm-offset.h 生成

    转自:https://blog.csdn.net/linglongqiongge/article/details/50008301 http://www.cnblogs.com/wendellyi/p ...

  10. 关于stm32优先级大小的理解

    转载自:https://www.cnblogs.com/ZKeJun/p/6112591.html 一. 组别:0>1>2>3>4   组别优先顺序(第0组优先级最强,第4组优 ...