码迷,mamicode.com
首页 > 编程语言 > 详细

Java 单元测试中的多线程无故退出

时间:2015-08-26 10:49:37      阅读:191      评论:0      收藏:0      [点我收藏+]

标签:

问题发现

最近在复习多线程相关知识,结果一动手就出现了问题,问题是这样的,在单元测试中使用多线程测试,发现只要子线程在睡眠一段时间,程序就退出了,毫无征兆!!!!

看看我的代码(请不要拘泥这段代码带来的并发问题):

 public class ThreadTest{
 
    class MyThread implements Runnable{
         
        private int count = 0 ;
         
        public void run(){
            try{
                Thread.sleep(1000); // 子线程休眠一秒,程序都退出
            }catch(InterruptedExcetption e ){
                e.printStackTrace();
            }
            while(count < 15){
                count ++;
                System.out.println(count);
            }
        }
    }
 
 
    @Test
    public void threadtest(){
         
        MyThread m1 = new MyThread();
         
        Thread t1 = new Thread(m1);
        Thread t2 = new Thread(m1);
        Thread t3 = new Thread(m1);
         
        t1.start(); // 子线程
        t2.start(); // 子线程
        t3.start(); // 子线程
        
        System.out.println(Thread.currentThread().getName()); // main 线程
    }


问题分析

最后查资料才发现:

原来这是单元测试的bug,如果把同样的程序放在main中运行是不会出现这个问题的!

具体JUnit源码我不知道,不过事实就是这样:你在单元测试中打印出当前线程的名称确实是main,

然后如果在单元测试中开启了线程,这个线程如果一直处于运行状态的话,那么就算单元测试运行完成,

子线程也不会退出;

但是,如果子线程处于阻塞、消亡状态,那么单元测试会立刻停止所有的子线程,同时退出程序!


问题解决

1)使子线程不处于阻塞状态,那么就算单元测试运行完成,子线程也不会退出;

2)可以强制要求所有子线程运行完成之后,在运行主线程,如下代码:

        t1.start(); // 子线程
        t2.start(); // 子线程
        t3.start(); // 子线程
        
        t3.join(); // 保证所有子线程运行完成之后,才运行下面的代码
        
        System.out.println(Thread.currentThread().getName()); // main 线程

3)不适用单元测试测试多线程,使用main进行测试


Java 单元测试中的多线程无故退出

标签:

原文地址:http://my.oschina.net/heweipo/blog/497176

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!