• Java八个并发学习——线程同步工具CyclicBarrier


    本文是一篇文章对网络的研究摘要,感谢您的无私分享。

    CyclicBarrier 类有一个整数初始值,此值表示将在同一点同步的线程数量。当当中一个线程到达确定点,它会调用await() 方法来等待其它线程。当线程调用这种方法,CyclicBarrier堵塞线程进入休眠直到其它线程到达。当最后一个线程调用CyclicBarrier 类的await() 方法,它唤醒全部等待的线程并继续运行它们的任务。

    注意比較CountDownLatch和CyclicBarrier:
    1.CountDownLatch的作用是同意1或N个线程等待其它线程完毕运行;而CyclicBarrier则是同意N个线程相互等待。


    2.CountDownLatch的计数器无法被重置。CyclicBarrier的计数器能够被重置后使用,因此它被称为是循环的barrier。

    package chapter3;
    
    import java.util.concurrent.CyclicBarrier;
    
    public class TestCyclicBarrier {
    
        private static final int THREAD_NUM = 5;
        
        public static class WorkerThread implements Runnable{
    
            CyclicBarrier barrier;
            
            public WorkerThread(CyclicBarrier b){
                this.barrier = b;
            }
            
            @Override
            public void run() {
                // TODO Auto-generated method stub
                try{
                    System.out.println("ID:"+Thread.currentThread().getId()+"Worker's waiting");
                    //线程在这里等待,直到全部线程都到达barrier。

    barrier.await(); System.out.println("ID:"+Thread.currentThread().getId()+" Working"); }catch(Exception e){ e.printStackTrace(); } } } /** * * <p> * </p> * @author zhangjunshuai * @date 2014-9-29 上午11:27:36 * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub CyclicBarrier cb = new CyclicBarrier(THREAD_NUM, new Runnable() { //当全部线程到达barrier时运行 @Override public void run() { // TODO Auto-generated method stub System.out.println("Inside Barrier"); } }); for(int i=0;i<THREAD_NUM;i++){ new Thread(new WorkerThread(cb)).start(); } } }



    版权声明:本文博主原创文章,博客,未经同意不得转载。

  • 相关阅读:
    统计一个字符串中字母、空格和数字的个数
    java 将一个数组中的值按逆序重新存放,例如,原来顺序为:9,5,7,4,8,要求改为:8,4,7, 5,9。
    java判断一个数是否为素数[转]
    Set集合
    List&ArrayList&LinkedList
    java_异常
    内部类&匿名内部类
    多态&抽象类&接口
    数组排序和字符串
    Java笔记_数据类型和运算符
  • 原文地址:https://www.cnblogs.com/hrhguanli/p/4855747.html
Copyright © 2020-2023  润新知