伍佰目录 短网址
  当前位置:海洋目录网 » 站长资讯 » 站长资讯 » 文章详细 订阅RssFeed

用栅栏(CyclicBarrier)实现高并发测试

来源:本站原创 浏览:113次 时间:2022-10-16
CyclicBarrier

含义:
栅栏允许两个或者多个线程在某个集合点同步。当一个线程到达集合点时,它将调用await()方法等待其它的线程。线程调用await()方法后,CyclicBarrier将阻塞这个线程并将它置入休眠状态等待其它线程的到来。等最后一个线程调用await()方法时,CyclicBarrier将唤醒所有等待的线程然后这些线程将继续执行。CyclicBarrier可以传入另一个Runnable对象作为初始化参数。当所有的线程都到达集合点后,CyclicBarrier类将Runnable对象作为线程执行。
方法
await():使线程置入休眠直到最后一个线程的到来之后唤醒所有休眠的线程

代码实现

原理:设置赛马集合点(线程启动需要一些时间),然后一起赛跑

package org.java;

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

import org.junit.Test;

public class TestCyclic {
@Test
public void test01() {
int count = 10;//并发线程数
CyclicBarrier cyclicBarrier = new CyclicBarrier(count);
ExecutorService executorService = Executors.newFixedThreadPool(count);
int n = 0;
for (int i = 0; i < count; i++) {

executorService.execute(new TestCyclic().new Task(cyclicBarrier, n));
n++;
}
executorService.shutdown(); // 关闭线程池
// 判断是否所有的线程已经运行完
while (!executorService.isTerminated()) {
try {
// 所有线程池中的线程执行完毕,执行后续操作
// TODO
System.out.println(“==============is sleep============”);
Thread.sleep(10000);
System.out.println(“==============is wake============”);

} catch (InterruptedException e) {
e.printStackTrace();
}
}
}

public class Task implements Runnable {
private CyclicBarrier cyclicBarrier;
int n = 0;

public Task(CyclicBarrier cyclicBarrier, int n) {
this.cyclicBarrier = cyclicBarrier;
this.n = n;
}

@Override
public void run() {
try {
// 等待所有任务准备就绪
System.out.println(“赛马” + n + “到达栅栏前”);
cyclicBarrier.await();
System.out.println(“赛马” + n + “开始跑”);
// 测试内容
System.out.println(“hello: ” + n);
} catch (Exception e) {
e.printStackTrace();
}
}
}
}

运行代码结果如下:

==============is sleep============
赛马0到达栅栏前
赛马1到达栅栏前
赛马3到达栅栏前
赛马2到达栅栏前
赛马4到达栅栏前
赛马5到达栅栏前
赛马7到达栅栏前
赛马6到达栅栏前
赛马8到达栅栏前
赛马9到达栅栏前
赛马9开始跑
赛马8开始跑
hello: 8
赛马6开始跑
hello: 6
赛马7开始跑
hello: 7
赛马0开始跑
hello: 0
赛马5开始跑
hello: 5
赛马4开始跑
hello: 4
赛马2开始跑
hello: 2
赛马3开始跑
hello: 3
赛马1开始跑
hello: 1
hello: 9
==============is wake============


  推荐站点

  • At-lib分类目录At-lib分类目录

    At-lib网站分类目录汇集全国所有高质量网站,是中国权威的中文网站分类目录,给站长提供免费网址目录提交收录和推荐最新最全的优秀网站大全是名站导航之家

    www.at-lib.cn
  • 中国链接目录中国链接目录

    中国链接目录简称链接目录,是收录优秀网站和淘宝网店的网站分类目录,为您提供优质的网址导航服务,也是网店进行收录推广,站长免费推广网站、加快百度收录、增加友情链接和网站外链的平台。

    www.cnlink.org
  • 35目录网35目录网

    35目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向35目录推荐、提交优秀网站。

    www.35mulu.com
  • 就要爱网站目录就要爱网站目录

    就要爱网站目录,按主题和类别列出网站。所有提交的网站都经过人工审查,确保质量和无垃圾邮件的结果。

    www.912219.com
  • 伍佰目录伍佰目录

    伍佰网站目录免费收录各类优秀网站,全力打造互动式网站目录,提供网站分类目录检索,关键字搜索功能。欢迎您向伍佰目录推荐、提交优秀网站。

    www.wbwb.net