一、应用背景
在实际的应用中,我们有时候需要启动多个线程来完成一项任务,而且要求多个线程在到达某一个点的时候停下来,等待所有的线程都到达这个点之后继续各自向下运行,这时候java.util.concurrent.CyclicBarrier就派上用场了。这里最重要的方法就是 await() ,当所有的线程都调用了该方法之后,这些线程才可以继续向下运行,否则将处于等待,等待所有的线程都调用这个方法。
案例,通过多线程统计一组数据:
package com.sino.thread;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
public class CyclicBarrierDemo implements Runnable{
private int count = 0;
private int num;
private CyclicBarrier barrier;
public CyclicBarrierDemo(CyclicBarrier barrier,int num) {
this.barrier = barrier;
this.num = num;
}
@Override
public void run() {
// TODO Auto-generated method stub
for(int i=0; i<num; i++) {
count = count + i;
}
System.out.println(Thread.currentThread().getName());
try {
barrier.await();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (BrokenBarrierException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+" 累加的和是:"+count);
}
}
测试类:
package com.sino.thread.test;
import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import com.sino.thread.CyclicBarrierDemo;
public class CyclicBarrierTest {
public static void main(String[] args) {
Runnable runner = new Runnable(){
@Override
public void run() {
System.out.println("开始计算");
}
};
CyclicBarrier barrier = new CyclicBarrier(2, runner);
CyclicBarrierDemo demo = new CyclicBarrierDemo(barrier,10);
ExecutorService exec = Executors.newFixedThreadPool(2);
Thread t1 = new Thread(demo,"t1");
Thread t2 = new Thread(demo,"t2");
exec.submit(t1);
exec.submit(t2);
exec.shutdown();
}
}
运行的结果:
pool-1-thread-1
pool-1-thread-2
开始计算
pool-1-thread-2 累加的和是:90
pool-1-thread-1 累加的和是:90
二、说明
执行到CyclicBarrier barrier = new CyclicBarrier(2, runner);时
Runnable的参数是在CyclicBarrier的数目达到2时并且所有线程调用.await()进入等待且未被唤醒前执行。 从输出结果可以看到,在两个线程都到达await()之后,才进入到runner对应的run方法中,之后两个线程继续向下执行
所以继续执行下面的两个线程
Thread t1 = new Thread(demo,"t1");
Thread t2 = new Thread(demo,"t2");
执行public void run()方法,分别执行,互不影响
执行到barrier.await();时该线程进入等待状态,当两个线程都执行完barrier.await();时,进入到new CyclicBarrier(2, runner);里面的run方法, 执行完里面的方法后,等待的两个线程再次被唤醒,继续各自执行线程后面的语句。
分享到:
相关推荐
`ThreadDemo`可能是一个简单的示例程序,它演示了如何使用`CyclicBarrier`来控制多个线程的同步行为。通常,这样的示例会创建多个线程,每个线程执行一些任务,然后在`CyclicBarrier`上等待,直到所有线程都完成任务...
CyclicBarrier的使用以及注意事项
java并发编程中CountDownLatch和CyclicBarrier的使用借鉴 java并发编程中CountDownLatch和CyclicBarrier是两个非常重要的线程控制和调度工具,经常被用于解决多线程程序设计中的线程等待问题。本文将对...
- 使用CyclicBarrier实现多线程分治策略,每个子任务完成后来一次全局计算的例子。 - 线程间的异常处理,包括中断和超时的处理。 - 结合Future和ExecutorService,进一步提高并发性能和灵活性。 - 在大型项目中的...
Java并发实例之CyclicBarrier的使用 CyclicBarrier是Java中的一种多线程并发控制实用工具,和CountDownLatch非常类似,它也可以实现线程间的计数等待,但是它的功能比CountDownLatch更加复杂且强大。CyclicBarrier...
在游戏场景中,如果四个玩家需要同时开始游戏,就可以使用CyclicBarrier。`CyclicBarrier(int parties, Runnable barrierAction)`构造函数接受两个参数,`parties`表示需要等待的线程数,`barrierAction`是所有线程...
Java多线程之CyclicBarrier的使用方法 Java多线程之CyclicBarrier的使用方法是Java多线程编程中的一种同步机制,用于实现多个线程之间的同步协作。CyclicBarrier是Java 5中引入的一种同步机制,用于让多个线程等待...
1. **重复使用性**:与CountDownLatch不同,CyclicBarrier可以在所有线程都达到屏障点后重置,允许再次使用。这意味着一旦所有线程都完成各自的任务并调用await()方法,屏障将被重置,计数器恢复到初始值,可以进行...
- **可重用性**:`CyclicBarrier`是可循环使用的,而`CountDownLatch`一旦计数到零就不能再使用。 - **屏障点动作**:`CyclicBarrier`允许指定当所有线程到达屏障点时执行的动作,而`CountDownLatch`没有这个功能。 ...
本文将详细介绍CountDownLatch和CyclicBarrier的工作原理、使用场景以及如何在实际项目中应用它们。 CountDownLatch和CyclicBarrier是Java并发编程中两个非常有用的同步工具,它们在不同的场景下有着各自的优势。...
Java并发系列之CyclicBarrier源码分析 CyclicBarrier是Java并发系列中的一种同步工具类,用于实现一组线程相互等待。当所有线程都到达某个屏障点后,再进行后续的操作。下面是对CyclicBarrier源码的详细分析。 ...
用CyclicBarrier,reentrantlock,condition来完成同时购买,同步购买的功能 JUC系列之模拟抢票(N人同时抢票,票不足系统补仓,N-M人继续抢票) http://blog.csdn.net/crazyzxljing0621/article/details/77891620
`CyclicBarrier`的名字来源于它的可重用性,一旦一组线程通过了屏障,它可以重置并再次使用,而不是像`CountDownLatch`那样只能使用一次。 在上述的测试代码中,我们创建了一个`CyclicBarrier`实例,设置了线程数为...
下面是一个使用CyclicBarrier的典型例子,展示了一个并行分解问题的解决过程: ```java class Solver { final int N; final float[][] data; final CyclicBarrier barrier; class Worker implements Runnable...
Java中的`CyclicBarrier`是用于多线程同步的一个强大工具,主要应用于一组线程需要在继续执行之前等待其他线程到达某个特定点的情况。它允许开发者定义一个屏障点,只有当所有参与的线程都到达这个屏障点时,它们才...
- 使用 CyclicBarrier 初始化 N 个线程,这些线程需要共同完成一个任务,只有当所有线程都准备好了之后,它们才能一起开始执行。 **实践案例:** 假设我们有一个复杂的任务,需要分阶段完成,而且每个阶段都需要...
在实际应用中,我们可以使用CyclicBarrier来控制多个线程之间的协作,例如,在游戏中,我们可以使用CyclicBarrier来控制四个玩家之间的协作,每个玩家需要到达某个关卡时,其他玩家也需要到达该关卡时,所有玩家才能...
4. CyclicBarrier 的一个重要特性是它可以循环使用。一旦所有线程完成当前轮次的同步,计数器会自动重置,允许下一轮同步。 在实际编程中,CyclicBarrier 可用于多种场景,例如多线程计算的初始化阶段,所有参与...
CyclicBarrier 的使用场景有很多,例如,在一个游戏中,所有玩家都需要等待其他玩家到达某个点时,可以使用 CyclicBarrier 来实现。又例如,在一个科学计算中,多个线程需要等待其他线程完成计算时,也可以使用 ...
CyclicBarrier(处理方案示例).md