multi-thread(十)CyclicBarrier
来源:互联网 发布:网络磁盘映射 编辑:程序博客网 时间:2024/06/06 02:12
Semaphore.acquire():最多n个运行,与Executors.newFixedThreadPool( 2 )作用相似
CyclicBarrier.await(): 加到n才开始
CountDownLatch.await(): 减到0才开始
/** * CyclicBarrier.await(): Waits until all parties have invoked await on this barrier. * @author timeriver.wang * @date Mar 10, 2014 10:43:52 AM */public class CyclicBarrierTest {public static void main(String[] args) {ExecutorService service = Executors.newCachedThreadPool();final CyclicBarrier cb = new CyclicBarrier(3);for(int i=0;i<3;i++){Runnable runnable = new Runnable(){public void run(){try {Thread.sleep((long)(Math.random()*1000));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();} catch (Exception e) {e.printStackTrace();}}};service.execute(runnable);}service.shutdown();}}
阅读全文
0 0
- multi-thread(十)CyclicBarrier
- multi-thread(一)基础知识
- multi-thread(二)ThreadGroup
- multi-thread(三)ExecutorService
- multi-thread(七)ReentrantReadWriteLock
- multi-thread(八)Semaphore
- multi-thread(九)CountDownLatch
- multi-thread
- Multi-Thread
- multi thread
- Python multi-process VS multi-thread (多核CPU利用率)
- [thread] multi-thread, thread attributes
- Python(11):多线程(Multi-Thread)
- multi-thread(六)ReentrantLock,Condition
- java Thread学习(新类库CountDownLatch+CyclicBarrier+DelayQueue)
- Java线程学习笔记(十)CountDownLatch 和CyclicBarrier
- java thread CountDownLatch and CyclicBarrier
- Multi-Thread Life
- multi-thread(八)Semaphore
- Hbase优化
- 通过代码,了解ThreadLocal
- multi-thread(九)CountDownLatch
- 简单多线程卖票代码
- multi-thread(十)CyclicBarrier
- [UIKBBlurredKeyView candidateList]:报错
- vue钩子函数的实现,基本原理就是callback
- Hbase RegionServer简单调优(GC)
- 4线程,2个对i加,2个对i减
- Reserved-7
- 通过代码,解释ExecutorService基本用法
- Reserved-8
- 学习:常用的数据适配器之PageAdapter