Junit测试中多线程的坑

昨晚用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
	}

这样改变代码之后,一切正常了!

本文《Junit测试中多线程的坑》来自 www.juwends.com ,欢迎转载或CV操作,但请注明出处,谢谢!