关闭

java.util.concurrent中:同步屏障CyclicBarrier

标签: javajava.util.concurrentCyclicBarrier同步屏障
210人阅读 评论(0) 收藏 举报
分类:

简介

CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(Barrier)。它要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活。CyclicBarrier默认的构造方法是CyclicBarrier(int parties),其参数表示屏障拦截的线程数量,每个线程调用await方法告诉CyclicBarrier我已经到达了屏障,然后当前线程被阻塞。

实例代码如下:

public class CyclicBarrierTest {
    static CyclicBarrier c = new CyclicBarrier(2);
    public static void main(String[] args) {
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    c.await();
                } catch (Exception e) {
                }
                System.out.println(1);
            }
        }).start();
        try {
            c.await();
        } catch (Exception e) {
        }
        System.out.println(2);
    }
}

输出

1 2
2 1

或者输出

1 1
2 2

如果把new CyclicBarrier(2)修改成new CyclicBarrier(3)则主线程和子线程会永远等待,因为没有第三个线程执行await方法,即没有第三个线程到达屏障,所以之前到达屏障的两个线程都不会继续执行。

CyclicBarrier还提供一个更高级的构造函数CyclicBarrier(int parties, Runnable barrierAction),用于在线程到达屏障时,优先执行barrierAction,方便处理更复杂的业务场景。代码如下:

public class CyclicBarrierTest2 {
    static CyclicBarrier c = new CyclicBarrier(2, new A());
    public static void main(String[] args) {
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    c.await();
                } catch (Exception e) {
                }
                System.out.println(1);
            }
        }).start();
        try {
            c.await();
        } catch (Exception e) {
        }
        System.out.println(2);
    }
    static class A implements Runnable {
        @Override
        public void run() {
            System.out.println(3);
        }
    }
}

输出

1 3
2 1
3 2

CyclicBarrier的应用场景

CyclicBarrier可以用于多线程计算数据,最后合并计算结果的应用场景。比如我们用一个Excel保存了用户所有银行流水,每个Sheet保存一个帐户近一年的每笔银行流水,现在需要统计用户的日均银行流水,先用多线程处理每个sheet里的银行流水,都执行完之后,得到每个sheet的日均银行流水,最后,再用barrierAction用这些线程的计算结果,计算出整个Excel的日均银行流水。

CyclicBarrier和CountDownLatch的区别

  • CountDownLatch的计数器只能使用一次。而CyclicBarrier的计数器可以使用reset() 方法重置。所以CyclicBarrier能处理更为复杂的业务场景,比如如果计算发生错误,可以重置计数器,并让线程们重新执行一次。
  • CyclicBarrier还提供其他有用的方法,比如getNumberWaiting方法可以获得CyclicBarrier阻塞的线程数量。isBroken方法用来知道阻塞的线程是否被中断。比如以下代码执行完之后会返回true。

isBroken的使用代码如下:

import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class CyclicBarrierTest3 {
    static CyclicBarrier c = new CyclicBarrier(2);
    public static void main(String[] args) throws Exception {
        Thread thread = new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    c.await();
                } catch (Exception e) {
                }
            }
        });
        thread.start();
        thread.interrupt();
        try {
            c.await();
        } catch (Exception e) {
            System.out.println(c.isBroken());
        }
    }
}

输出

true
转载自并发编程网 – ifeve.com本文链接地址: 并发工具类(二)同步屏障CyclicBarrier
0
0
查看评论

Java并发编程的艺术(八)——闭锁、同步屏障、信号量详解

1. 闭锁:CountDownLatch1.1 使用场景若有多条线程,其中一条线程需要等到其他所有线程准备完所需的资源后才能运行,这样的情况可以使用闭锁。1.2 代码实现// 初始化闭锁,并设置资源个数 CountDownLatch latch = new CountDownLatch(2);Thr...
  • u010425776
  • u010425776
  • 2017-01-17 09:23
  • 1414

Java多线程/并发23、循环屏障CyclicBarrier

CyclicBarrier 直译叫循环屏障或循环分界点。让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续工作。打个比方,F1大奖赛共5支车队参赛。第一站:上海站。比赛马上要开始了,各个车队都在准备,但是先到达起跑线准备就绪的车队...
  • soonfly
  • soonfly
  • 2017-05-04 21:03
  • 564

同步屏障CyclicBarrier

原文出自:并发编程网 – ifeve.com    http://ifeve.com/concurrency-cyclicbarrier/ 简介     CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(...
  • lihe2008125
  • lihe2008125
  • 2016-01-24 14:05
  • 360

Linux线程同步------屏障

屏障是Linux中协调多个线程并行工作的同步机制,屏障允许每个线程等待直到所有的合作线程到达某一点,然后继续从该点执行,pthread_join是一种屏障但只允许一个线程等待,pthread_barrier允许任意数量的线程等待!
  • xieshangjian
  • xieshangjian
  • 2014-11-06 15:39
  • 1188

Java多线程--同步屏障CyclicBarrier

简介 CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(Barrier)。它要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活。CyclicBarrier默认的构造方法是Cyclic...
  • hello_worldee
  • hello_worldee
  • 2017-09-07 13:22
  • 60

并发工具类:同步屏障CyclicBarrier

参考链接:http://ifeve.com/concurrency-cyclicbarrier/ CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(Barrier)。它要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会解除,...
  • kusedexingfu
  • kusedexingfu
  • 2017-05-25 19:59
  • 2424

java.util.concurrent下同步辅助类CyclicBarrier

        CyclicBarrier--同步辅助类,它允许一组线程相互等待,直到到达某个公共屏障点(common barrier point),在涉及一组固定大小的线程的程序中,这些线程必须不时的互相等待,此时Cy...
  • USTC_Zn
  • USTC_Zn
  • 2018-02-09 19:14
  • 17

并发工具类(二)同步屏障CyclicBarrier

简介 CyclicBarrier 的字面意思是可循环使用(Cyclic)的屏障(Barrier)。它要做的事情是,让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活。CyclicBarrier默认的构造方法是Cyclic...
  • quan7394
  • quan7394
  • 2017-09-14 02:55
  • 69

java并发之同步屏障CyclicBarrier

CyclicBarrier 是让一组线程到达一个屏障(也可以叫同步点)时被阻塞,直到最后一个线程到达屏障时,屏障才会开门,所有被屏障拦截的线程才会继续干活。CyclicBarrier默认的构造方法是CyclicBarrier(int parties),其参数表示屏障拦截的线程数量,每个线程调用awa...
  • qq_35807697
  • qq_35807697
  • 2017-10-14 17:01
  • 84

闭锁、同步屏障、信号量详解

转载自:http://blog.csdn.net/u010425776/article/details/54580082 1. 闭锁:CountDownLatch 1.1 使用场景 若有多条线程,其中一条线程需要等到其他所有线程准备完所需的资源后才能运行,这样的情况可以使用闭锁。 ...
  • zs064811
  • zs064811
  • 2017-07-27 11:01
  • 130
    个人资料
    • 访问:155942次
    • 积分:2870
    • 等级:
    • 排名:第14607名
    • 原创:126篇
    • 转载:26篇
    • 译文:0篇
    • 评论:9条
    博客专栏
    文章分类
    最新评论