Junit测试中多线程的坑

发表于:2016-9-21 10:34

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:Juwend's    来源:51Testing软件测试网采编

  昨晚用Junit测试多线程,代码如下:
private int i = 3;
@Test
public void test() {
for (int i = 0; i < this.i; i ++) {
new Thread(new Runner()).start();
}
}
class Runner implements Runnable {
@Override
public void run() {
System.out.printlun(123);
}
}
  发现运行后居然没有任何输出…我又运行了好几次,有时又有1~2句输出,但是始终不全…
  当时还以为程序有错,clean了class继续,还是一样的,今天早上起来查了下百度,才明白,原来Junit只管自己的运行,就是说当Junit执行完毕后,就会关闭程序,不会关心是否还有自己启动的后台线程在运行。当Junit运行完毕后,如果后台线程还没有执行完毕,那么也是不会再执行了,所以就出现了昨天的情况…
  我始终对多线程的执行过程没有意识呢…主线程和后台线程的关系和执行一定要搞清楚呢…
  现在既然搞清楚了,那就好办了,下面代码展示如何优雅的将Junit主线程设置为同步线程:
private int i = 3;
/*
* 线程计数器
将线程数量初始化
每执行完成一条线程,调用countDown()使计数器减1
主线程调用方法await()使其等待,当计数器为0时才被执行
*/
private CountDownLatch latch = new CountDownLatch(i);
@Test
public void test() {
for (int i = 0; i < this.i; i ++) {
new Thread(new Runner()).start();
}
try {
latch.await(); // 主线程等待
} catch (InterruptedException e) {
e.printStackTrace();
}
}
class Runner implements Runnable {
@Override
public void run() {
System.out.printlun(123);
latch.countDown(); // 执行完毕,计数器减1
}
  这样改变代码之后,一切正常了!
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号