JUC之CyclicBarrier循环避障

举例说明CyclicBarrier循环避障:
        游乐园水上划船,规定5个人划一艘船,如果人不够,那么就需要等待,直到凑齐5个人了,才允许开始。也就是说,5个人一波5个人一波。每一波都是同一时间开始玩的。

即:循环避障保证了多个线程在准确的同一刻开始。

注:CyclicBarrier循环避障适用于多线程必须同时开始的情景。

 

代码示例

import java.util.Date;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

/**
 * 循环避障 示例
 *
 * @author JustryDeng
 * @date 2018/10/17 19:39
 */
public class CyclicBarrierDemo {

    /** 设置循环避障数 */
    private static CyclicBarrier cyclicBarrier = new CyclicBarrier(5);

    public static void main(String[] args) throws InterruptedException {
        // -> 创建可缓存长线程池
        ExecutorService executorService = Executors.newCachedThreadPool();
        for (int i = 1; i <= 10; i++) {
            Thread.sleep(1000);
            // 使用lambel表达式简单实现Runnable接口的run方法
            executorService.execute(() -> {
                try {
                    System.out.println(new Date() + "线程" + Thread.currentThread().getName() + "准备就绪!");
                    // 设置避障点
                    cyclicBarrier.await();
                    System.out.println(new Date() + "线程" + Thread.currentThread().getName() + "开始运行!");
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } catch (BrokenBarrierException e) {
                    e.printStackTrace();
                }
            });
        }
        // 关闭线程池
        executorService.shutdown();
    }
}

运行主函数,输出结果为:

注:await(long timeout, TimeUnit unit)方法可以设置一个超时时间,如果等待超时了,那么会抛出异常;其它同组等待的线程
      就知道不需要等了,没有结果的。

注:CyclicBarrier常用场景有(举例说明):
        1.双十一00:00分秒杀
        2.准点抢票
        3.跑分测试
         ……

 

注:本人多线程一栏的文章大多为简记、后续时间充裕了再回头进行丰富。

声明:本文是学习笔记,主要学习自以下视频
微笑学习视频
           《Java多线程与并发实战视频课程》,齐毅 
微笑如有不当之处,欢迎指正
微笑本文已经被收录进《程序员成长笔记(三)》,笔者JustryDeng

猜你喜欢

转载自blog.csdn.net/justry_deng/article/details/83117229
今日推荐