码迷,mamicode.com
首页 > 其他好文 > 详细

CyclicBarrier如何使用?

时间:2019-12-26 09:42:46      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:bsp   countdown   线程   ant   ast   理解   get   str   ima   

  • CyclicBarrier 的中文意思是 "循环栅栏",简单理解就是一个可以循环利用的屏障。
  • 用于让多个线程阻塞在屏障处,当屏障达到放开的条件,所有被阻塞的线程会继续执行,此时 CyclicBarrier 会自动重置。
  • 阻塞线程在屏障处,调用 CyclicBarrier 对象的 await() 方法
  • CyclicBarrier 内部主要通过了 ReentrantLock 和 Condition 实现
  • CyclicBarrier 有两个构造方法:
//parties 表示屏障拦截的线程数量
//barrierAction 表示最后一个达到的屏障的线程将执行 barrierAction
public CyclicBarrier(int parties)
public CyclicBarrier(int parties, Runnable barrierAction)

 

 

使用示例:

package constxiong.interview;

import java.util.concurrent.CyclicBarrier;

/**
 * 测试 CyclicBarrier 的使用
 * @author ConstXiong
 * @date 2019-12-25 19:22:50
 */
public class TestCyclicBarrier {

    public static void main(String[] args) {
        int parts = 10;
        final CyclicBarrier cb = new CyclicBarrier(parts, () -> {
            System.out.println(Thread.currentThread().getName() + ": I‘am is last Thread");
        });
        
        for (int i = 0; i < 10; i++) {
            new Thread(() -> {
                System.out.println(Thread.currentThread().getName() + ": I‘am come");
                try {
                    cb.await();
                } catch (Exception e) {
                    e.printStackTrace();
                }
                System.out.println(Thread.currentThread().getName() + ": go together");
            }).start();
        }
        
    }
    
}

 

 

打印结果:

Thread-2: Iam come
Thread-0: Iam come
Thread-1: Iam come
Thread-4: Iam come
Thread-3: Iam come
Thread-6: Iam come
Thread-9: Iam come
Thread-5: Iam come
Thread-7: Iam come
Thread-8: Iam come
Thread-8: Iam is last Thread
Thread-8: go together
Thread-2: go together
Thread-0: go together
Thread-1: go together
Thread-4: go together
Thread-3: go together
Thread-6: go together
Thread-5: go together
Thread-9: go together
Thread-7: go together

 

 

CountDownLatch 和 CyclicBarrier 简单比较

  • CountDownLatch 是一个(或多个)线程等待 N 个线程完成某件事情之后再执行;CyclicBarrier 是每个线程相互等待,即 N 个线程都被拦截之后,然后一起放开执行
  • CountDownLatch 无法重置,不可复用;CyclicBarrier 计数到 parts 值时会自动重置,可复用


原文链接
 


技术图片

 

 

CyclicBarrier如何使用?

标签:bsp   countdown   线程   ant   ast   理解   get   str   ima   

原文地址:https://www.cnblogs.com/ConstXiong/p/12100250.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!