当前位置

网站首页> 程序设计 > 开源项目 > 程序开发 > 浏览文章

junit 不能用于测试多线程

作者:小梦 来源: 网络 时间: 2024-07-17 阅读:

线程类:

public class Thread1 implements Runnable {    @Override    public void run() {        // TODO Auto-generated method stub        for(int i=0;i<10000;i++){System.out.print(i+" ");        }    }        }

测试类:

public class MultiThreadTest {        @Test    public void test() throws IOException, InterruptedException{        Runnable  Thread1 = new Thread1();        new Thread(Thread1).start();    //    Thread.sleep(10000);        System.out.println(" main thread terminate");    }    }

输出结果:

terminate0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20

总结:

在线程类中,循环打印10000 个数字,但是在测试类中只打印了一部分.如果在测试类中把Thread.sleep() 的注释去掉,则可以打印全部的数字.
如果把代码放到正常的main() 中执行,也可以打印全部数字出来.

其实junit是将test作为参数传递给了TestRunner的main函数。并通过main函数进行执行。test函数在main中执行。如果test执行结束,那么main将会调用System.exit(0);
即使还有其他的线程在运行,main也会调用System.exit(0);
System.exit()是系统调用,通知系统立即结束jvm的运行,即使jvm中有线程在运行,jvm也会停止的。所以会出现之前的那种情况。其中System.exit(0);的参数如果是0,表示系统正常退出,如果是非0,表示系统异常退出。

junit TestRunner 部分源代码:

junit.textui.TestRunner public static void main (String[] args) {      TestRunner aTestRunner = new TestRunner();      try {        TestResult r = aTestRunner.start(args);       if (!(r.wasSuccessful()))          System.exit (1);       System.exit(0);      } catch (Exception e) {       System.err.println(e.getMessage());        System.exit(2);      }   }

相关阅读

热点阅读

网友最爱