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. C++二进制文件中读写bitset

    这个比较简单,直接上代码: bitset< > *b = >(); bitset< > *c = >(); ofstream out("I:\\test. ...

  2. WebService Ajax调用

    1.Html <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  3. 关于VS2013中Win32程序怎么修改图标

    首先向资源文件上加上你要添加的资源(把你要添加的图标放在你的工程的下面,然后右击资源文件选中添加资源,然后选择导入你要添加的图标),下面你只要打开你项目的.rc文件要用查看代码形式打开,然后只要把系统 ...

  4. Winform基础知识

    1.关于登陆部分 this.DialogResult = DialogResult.OK; this.Close(); FrmLogin login = new FrmLogin(m_CurUser) ...

  5. maven .assembly

    配置文件中 配置好Assemblyc插件. 功能:打依赖jar包. java代码如下: <assembly xmlns="http://maven.apache.org/plugins ...

  6. Hubilder快捷键

    /* tips.txt的内容可以在HBuilder启动封面中显示.你可以自定义一个有趣的启动tips,增加[user]开头的文本内容即可.比如[user]我要减肥!  */ 你按照Hello HBui ...

  7. Scalding初探之三:Hadoop实战

    Java版本 如果在Scala工程中混入Java类导致java版本不match,可能会抛错 java.lang.UnsupportedClassVersionError: XXX Unsupporte ...

  8. codeforces194b

    link:http://codeforces.com/problemset/problem/334/B #include <iostream> #include <cstdio> ...

  9. Ioc正解

    IoC是一种模式 IoC(Inversion of Control)中文译为控制反转,目前Java社群中流行的各种轻量级容器的实现都是以IoC模式作为基础的.控制反转意味着在系统开发过程中,设计的类将 ...

  10. 加速你的py.test, pytest-dist

    URL: https://pypi.python.org/pypi/pytest-xdist 多线程跑测试 Command: py.test -d --tx 3*popen