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

问题发现

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

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

 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进行测试


转载于:https://my.oschina.net/heweipo/blog/497176

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值