码迷,mamicode.com
首页 > 编程语言 > 详细

java路障CyclicBarrier

时间:2017-01-14 23:11:10      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:port   rgs   dom   span   pool   ++   nbsp   ati   executors   

当所有线程都执行到某行代码,才可已往下执行:

package threadLock;

import java.util.Random;
import java.util.concurrent.BrokenBarrierException;
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 barrier = new CyclicBarrier(3);
        for(int i = 0; i < 3; ++i){
            Runnable runnable  = new Runnable() {
                
                @Override
                public void run() {
                    
                        try {
                            Thread.sleep(new Random().nextInt(1000));
                            System.out.println("线程 " + Thread.currentThread().getName() + "即将到达目的地 1,当前已有" + (barrier.getNumberWaiting() + 1) + "个到达," + (barrier.getNumberWaiting() == 2 ? "继续走啊" : "") );
                            barrier.await();
                            Thread.sleep(new Random().nextInt(1000));
                            System.out.println("线程 " + Thread.currentThread().getName() + "即将到达目的地 2,当前已有" + (barrier.getNumberWaiting() + 1) + "个到达," + (barrier.getNumberWaiting() == 2 ? "继续走啊" : "") );
                            barrier.await();
                            Thread.sleep(new Random().nextInt(1000));
                            System.out.println("线程 " + Thread.currentThread().getName() + "即将到达目的地 3,当前已有" + (barrier.getNumberWaiting() + 1) + "个到达," + (barrier.getNumberWaiting() == 2 ? "继续走啊" : "") );
                            barrier.await();
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        } catch (BrokenBarrierException e) {
                            e.printStackTrace();
                        }
                    }
                    
                
            };
            service.execute(runnable);
        }
    }
}

 

java路障CyclicBarrier

标签:port   rgs   dom   span   pool   ++   nbsp   ati   executors   

原文地址:http://www.cnblogs.com/zhouquan-1992-04-06/p/6286256.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!