手机
当前位置:查字典教程网 >编程开发 >Java >java线程并发cyclicbarrier类使用示例
java线程并发cyclicbarrier类使用示例
摘要:复制代码代码如下:packagecom.yao;importjava.util.Random;importjava.util.concurr...

复制代码 代码如下:

package com.yao;

import java.util.Random;

import java.util.concurrent.CyclicBarrier;

/**

* CyclicBarrier类似于CountDownLatch也是个计数器,

* 不同的是CyclicBarrier数的是调用了CyclicBarrier.await()进入等待的线程数,

* 当线程数达到了CyclicBarrier初始时规定的数目时,所有进入等待状态的线程被唤醒并继续。

* CyclicBarrier就象它名字的意思一样,可看成是个障碍,

* 所有的线程必须到齐后才能一起通过这个障碍。

* CyclicBarrier初始时还可带一个Runnable的参数,

* 此Runnable任务在CyclicBarrier的数目达到后,所有其它线程被唤醒前被执行。

*/

public class CyclicBarrierTest {

public static class ComponentThread implements Runnable {

CyclicBarrier barrier;// 计数器

int ID;// 组件标识

int[] array;// 数据数组

// 构造方法

public ComponentThread(CyclicBarrier barrier, int[] array, int ID) {

this.barrier = barrier;

this.ID = ID;

this.array = array;

}

public void run() {

try {

array[ID] = new Random().nextInt(100);

System.out.println("Component " + ID + " generates: " + array[ID]);

// 在这里等待Barrier处

System.out.println("Component " + ID + " sleep...");

barrier.await();

System.out.println("Component " + ID + " awaked...");

// 计算数据数组中的当前值和后续值

int result = array[ID] + array[ID + 1];

System.out.println("Component " + ID + " result: " + result);

} catch (Exception ex) {

}

}

}

/**

* 测试CyclicBarrier的用法

*/

public static void testCyclicBarrier() {

final int[] array = new int[3];

CyclicBarrier barrier = new CyclicBarrier(2, new Runnable() {

// 在所有线程都到达Barrier时执行

public void run() {

System.out.println("testCyclicBarrier run...");

array[2] = array[0] + array[1];

}

});

// 启动线程

new Thread(new ComponentThread(barrier, array, 0)).start();

new Thread(new ComponentThread(barrier, array, 1)).start();

}

public static void main(String[] args) {

CyclicBarrierTest.testCyclicBarrier();

}

}

【java线程并发cyclicbarrier类使用示例】相关文章:

java线程并发semaphore类示例

java多线程并发executorservice(任务调度)类

java多线程和并发包入门示例

java调用c程序通信示例代码

java多线程入门知识及示例程序

java中File类的使用方法

Java中CyclicBarrier的用法分析

java枚举的使用示例

java中final关键字使用示例详解

java线程之线程的生命周期的使用

精品推荐
分类导航