package a.jery;

import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; public class Jery { public static void main(String[] args) {
ExecutorService service = Executors.newCachedThreadPool();
final CyclicBarrier cb=new CyclicBarrier(5,new Runnable(){
@Override
public void run() {
System.out.println("人都到齐了,我们开始吧!");
try {
System.out.println("...singing...singing...");
Thread.sleep((long)(Math.random()*1000)+4000);//唱4秒到5秒
System.out.println("...singing...singing...");
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("表演结束,大家回家吃饭吧!");
System.exit(0);
}
});
System.out.println(String.format("大家好,下面我们需要%s人合唱,有自愿者请上台", cb.getParties()));
for(int i=1;i<=5;i++){
service.execute(new Runnable(){
@Override
public void run() {
try {
Thread.sleep((long)(Math.random()*100));//为了看到效果,每个线程花费点时间
System.out.println(String.format("目前已有%s人上台", cb.getNumberWaiting()));
System.out.println(String.format("。呀,有人举手了,有请%s号上台", Thread.currentThread().getId()));
cb.await();
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
} }

执行结果:

大家好,下面我们需要5人合唱,有自愿者请上台
目前已有0人上台
。呀,有人举手了,有请12号上台
目前已有1人上台
。呀,有人举手了,有请10号上台
目前已有2人上台
。呀,有人举手了,有请13号上台
目前已有3人上台
。呀,有人举手了,有请9号上台
目前已有4人上台
。呀,有人举手了,有请11号上台
人都到齐了,我们开始吧!
...singing...singing...
...singing...singing...
表演结束,大家回家吃饭吧!

这是一个最简单的演示,下面我们来看看循环屏障的真正好处:

package a.jery;

import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors; public class Jery { public static void main(String[] args) {
final ExecutorService service = Executors.newCachedThreadPool();
final CyclicBarrier cb=new CyclicBarrier(5,new Runnable(){
@Override
public void run() {
System.out.println("人都到齐了,我们开始吧!");
try {
System.out.println("...singing...singing...");
Thread.sleep((long)(Math.random()*1000)+4000);//唱4秒到5秒
System.out.println("...singing...singing...");
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("表演结束,大家回家吃饭吧!");
System.out.println("----------------");
System.out.println("大家吃好饭了吧,请唱歌的同学再次上台,我们要演奏下一首歌。");
}
});
System.out.println(String.format("大家好,下面我们需要%s人合唱,有自愿者请上台", cb.getParties()));
for(int i=1;i<=5;i++){
service.execute(new Runnable(){
@Override
public void run() {
try {
Thread.sleep((long)(Math.random()*100));//为了看到效果,每个线程花费点时间
System.out.println(String.format("目前已有%s人上台", cb.getNumberWaiting()));
System.out.println(String.format("。呀,有人举手了,有请%s号上台", Thread.currentThread().getId()));
cb.await();
//注意此处代码须在5人都上台并演唱结束后才能执行
Thread.sleep((long)(Math.random()*100));//为了看到效果,每个线程花费点时间
System.out.println(String.format("第二首歌已有%s人上台", cb.getNumberWaiting()));
System.out.println(String.format("有请%s号上台", Thread.currentThread().getId()));
cb.await();//此处又可以唱歌了,这就是循环屏障和CountDownLantch的最大区别。可以循环利用
System.out.println("我擦,怎么又要唱了,老子不干了");
Thread.currentThread().interrupt();
System.out.println("有你这么用人的吗?老子拆了你舞台.");
service.shutdown();
System.out.println("...bom...bom...");
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
} }

执行结果:

大家好,下面我们需要5人合唱,有自愿者请上台
目前已有0人上台
。呀,有人举手了,有请11号上台
目前已有1人上台
。呀,有人举手了,有请12号上台
目前已有2人上台
。呀,有人举手了,有请9号上台
目前已有3人上台
。呀,有人举手了,有请10号上台
目前已有4人上台
。呀,有人举手了,有请13号上台
人都到齐了,我们开始吧!
...singing...singing...
...singing...singing...
表演结束,大家回家吃饭吧!
----------------
大家吃好饭了吧,请唱歌的同学再次上台,我们要演奏下一首歌。
第二首歌已有0人上台
有请9号上台
第二首歌已有1人上台
有请12号上台
第二首歌已有2人上台
有请11号上台
第二首歌已有3人上台
有请13号上台
第二首歌已有4人上台
有请10号上台
人都到齐了,我们开始吧!
...singing...singing...
...singing...singing...
表演结束,大家回家吃饭吧!
----------------
大家吃好饭了吧,请唱歌的同学再次上台,我们要演奏下一首歌。
我擦,怎么又要唱了,老子不干了
我擦,怎么又要唱了,老子不干了
有你这么用人的吗?老子拆了你舞台.
我擦,怎么又要唱了,老子不干了
有你这么用人的吗?老子拆了你舞台.
有你这么用人的吗?老子拆了你舞台.
我擦,怎么又要唱了,老子不干了
有你这么用人的吗?老子拆了你舞台.
我擦,怎么又要唱了,老子不干了
有你这么用人的吗?老子拆了你舞台.
...bom...bom...
...bom...bom...
...bom...bom...
...bom...bom...
...bom...bom...

CyclicBarrier类合唱演绎的更多相关文章

  1. java 5线程中 Semaphore信号灯,CyclicBarrier类,CountDownLatch计数器以及Exchanger类使用

    先来讲解一下Semaphore信号灯的作用:  可以维护当前访问自身的线程个数,并提供了同步机制, 使用semaphore可以控制同时访问资源的线程个数 例如,实现一个文件允许的并发访问数. 请看下面 ...

  2. JAVA CyclicBarrier类详解

    一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点 (common barrier point).在涉及一组固定大小的线程的程序中,这些线程必须不时地互相等待,此时CyclicBarrie ...

  3. JUC——线程同步辅助工具类(Semaphore,CountDownLatch,CyclicBarrier)

    锁的机制从整体的运行转态来讲核心就是:阻塞,解除阻塞,但是如果仅仅是这点功能,那么JUC并不能称为一个优秀的线程开发框架,然而是因为在juc里面提供了大量方便的同步工具辅助类. Semaphore信号 ...

  4. java并发编程工具类辅助类:CountDownLatch、CyclicBarrier和 Semaphore

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

  5. Java中的并发工具类:CountDownLatch、CyclicBarrier和Semaphore

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

  6. Java多线程同步工具类之CyclicBarrier

    一.CyclicBarrier使用 CyclicBarrier从字面上可以直接理解为线程运行的屏障,它可以让一组线程执行到一个共同的屏障点时被阻塞,直到最后一个线程执行到指定位置,你设置的执行线程就会 ...

  7. 【JUC】JDK1.8源码分析之CyclicBarrier(四)

    一.前言 有了前面分析的基础,现在,接着分析CyclicBarrier源码,CyclicBarrier类在进行多线程编程时使用很多,比如,你希望创建一组任务,它们并行执行工作,然后在进行下一个步骤之前 ...

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

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

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

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

随机推荐

  1. Scala深入浅出实战经典---001-Scala开发环境搭建和HelloWorld解析

    001-Scala开发环境搭建和HelloWorld解析 Scala 函数式编程和面向对象结合的语言 函数式编程擅长数值计算 面向对象擅长大型工程和项目的组织以及团队的分工协作 Scala会是下一个伟 ...

  2. 简单工厂模式(Simple Factory)

    从设计模式的类型上来说,简单工厂模式是属于创建型模式,又叫做静态工厂方法(Static Factory Method)模式,但不属于23种GOF设计模式之一.简单工厂模式是由一个工厂对象决定创建出哪一 ...

  3. 58.com qiyi

    using AnfleCrawler.Common; using System; using System.Collections.Generic; using System.Linq; using ...

  4. 两个小的java程序,用于练习java基本语法

    1.输入两个数,求其加减乘除.用窗口的形式呈现 import javax.swing.JOptionPane; public class JJCC { public static void main( ...

  5. 团队开发——冲刺2.a

    冲刺阶段二(第一天) 1.今天准备做什么? 收集游戏图片:开始.暂停.继续.重新开始.退出……为了界面的后期美工做准备. 2.遇到什么困难? 网上的图片很多,但是比较难找到统一风格的.

  6. echo、print、sprint、sprintf输出

    echo() 函数 定义和用法 echo() 函数输出一个或多个字符串. 语法 echo(strings) 参数 描述 strings 必需.一个或多个要发送到输出的字符串. 提示和注释 注释:ech ...

  7. JavaScript闭包学习笔记

    此文都是大牛们关于闭包的观点,在此只是总结. 闭包应用的两种情况即可——函数作为返回值,函数作为参数传递. 1 深入理解javascript原型和闭包 判断一个变量是不是对象非常简单.值类型的类型判断 ...

  8. 12-8下午 php语法

    <?php //var_dump(empty($a)); //判断变量是否为空//var_dump(isset($a)); //判断变量是否定义//$a = 10;//unset($a); // ...

  9. WebDriver定位元素方法

    如果把页面上的元素看作人的话,在现实世界如何找到某人呢?方法有三: 一.通过人本身的属性,例如他的姓名,手机号,身份证号,性别,这些可区别他人的属性.在web页面上的元素也有这些属性,例如,id.na ...

  10. C#对象复制 ICloneable

    在.net framework中,提供了ICloneable接口来对对象进行克隆.当然,你也可以不去实现ICloneable接口而直接自己定义一个Clone()方法,当然,还是推荐实现ICloneab ...