CyclicBarrier的用法

简介: 多个线程在指定的集合点(屏障点)等待集合后在继续去下一个集合点import java.util.concurrent.CyclicBarrier;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;public class CyclicBarrierTest {   

多个线程在指定的集合点(屏障点)等待集合后在继续去下一个集合点

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


public class CyclicBarrierTest {

    public static void main(String[] args) {
        ExecutorService service = Executors.newCachedThreadPool();
        final  CyclicBarrier cb = new CyclicBarrier(3);//设置等待到达的线程数目
        Runnable runnable = new Runnable(){
            public void run(){
            try {
                Thread.sleep((long)(Math.random()*10000));    
                System.out.println("线程" + Thread.currentThread().getName() + 
                        "即将到达集合地点1,当前已有" + (cb.getNumberWaiting()+1) + "个已经到达,"+(cb.getNumberWaiting()==2?"都到齐了继续走呀":"正在等候"));                        
                cb.await();//到此如果没有达到公共屏障点,则该线程处于等待状态,如果达到公共屏障点则所有处于等待的线程都继续往下运行
                
                Thread.sleep((long)(Math.random()*10000));    
                System.out.println("线程" + Thread.currentThread().getName() + 
                        "即将到达集合地点2,当前已有" + (cb.getNumberWaiting()+1) + "个已经到达,"+(cb.getNumberWaiting()==2?"都到齐了继续走呀":"正在等候"));                  
                cb.await();    
                Thread.sleep((long)(Math.random()*10000));    
                System.out.println("线程" + Thread.currentThread().getName() + 
                        "即将到达集合地点3,当前已有" + (cb.getNumberWaiting()+1) + "个已经到达,"+(cb.getNumberWaiting()==2?"都到齐了继续走呀":"正在等候"));                  
                cb.await();                        
            } catch (Exception e) {
                e.printStackTrace();
            }                
        }
    };
        for(int i=0;i<3;i++){        
            service.execute(runnable);
        }
        service.shutdown();
    }
}


本文出自 “点滴积累” 博客,请务必保留此出处http://tianxingzhe.blog.51cto.com/3390077/1716837

目录
相关文章
|
4月前
|
Java 数据库 开发者
CountDownLatch、CyclicBarrier和Semaphore原理和区别
CountDownLatch、CyclicBarrier和Semaphore
|
2月前
|
Java C++
【多线程】JUC的常见类,Callable接口,ReentranLock,Semaphore,CountDownLatch
【多线程】JUC的常见类,Callable接口,ReentranLock,Semaphore,CountDownLatch
35 0
|
4月前
CyclicBarrier原理
文章主要介绍了CyclicBarrier的工作原理和使用场景。CyclicBarrier适用于需要多个线程同步到达某个点后再一起继续执行的情况,它通过ReentrantLock和Condition实现了高效的线程同步机制,适合用于需要循环使用屏障点的场景。
CyclicBarrier原理
|
4月前
|
Java
CountDownLatch、CyclicBarrier 使用区别
CountDownLatch、CyclicBarrier 使用区别
34 1
|
5月前
|
Java 测试技术 开发者
Java面试题:解释CountDownLatch, CyclicBarrier和Semaphore在并发编程中的使用
Java面试题:解释CountDownLatch, CyclicBarrier和Semaphore在并发编程中的使用
79 11
|
7月前
|
Java
CountDownLatch用法、详解
CountDownLatch用法、详解
|
7月前
并发编程之CountDownLatch和CyclicBarrier的详细解析(带小案例)
并发编程之CountDownLatch和CyclicBarrier的详细解析(带小案例)
94 0
CountDownLatch和CyclicBarrier的区别
CountDownLatch和CyclicBarrier的区别
39 0
CyclicBarrier 和 CountDownLatch 的实现原理与代码演示
CyclicBarrier 和 CountDownLatch 的实现原理与代码演示
168 0