java5的CyclicBarrier同步工具

1、概述

    一、表示你們彼此等待,你們集合好後纔開始出發,分散活動後又在指定地點集合碰面,這就比如整個公司的人員利用週末時間集體郊遊同樣,先各自從家出發到公司集合後,再同時出發到公園遊玩,在指定地點集合後再同時開始就餐,…java

    二、Cyclic:循環的,有周期性的 Barrier:障礙物,屏障 dom

2、代碼描述

    一、CyclicBarrierTest

package com.lh.threadtest.t12;

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

/****
 * 
 * @ClassName: CyclicBarrierTest
 * @Description: java5的CyclicBarrier同步工具
 * @author Liu
 * @date 2018年1月18日 下午4:35:08
 *
 */
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() * 10000));
						System.out.println("線程" + Thread.currentThread().getName() + "即將到達集合地點1,當前已有"
								+ cb.getNumberWaiting() + "個已經到達,正在等候");
						cb.await();

						Thread.sleep((long) (Math.random() * 10000));
						System.out.println("線程" + Thread.currentThread().getName() + "即將到達集合地點2,當前已有"
								+ cb.getNumberWaiting() + "個已經到達,正在等候");
						cb.await();
						Thread.sleep((long) (Math.random() * 10000));
						System.out.println("線程" + Thread.currentThread().getName() + "即將到達集合地點3,當前已有"
								+ cb.getNumberWaiting() + "個已經到達,正在等候");
						cb.await();
					} catch (Exception e) {
						e.printStackTrace();
					}
				}
			};
			service.execute(runnable);
		}
		service.shutdown();
	}
}
相關文章
相關標籤/搜索