Thread中有一个public final void join () 方法是让当前线程去等待调用这个join方法的那个线程的结束。
看下面一个例子
public class TestThreadException {
/**
* @param args
*/
public static void main(String[] args) {
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
System.out.println("New thread is working");
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
throw new RuntimeException(" Excpetion occurs in brach thread");
}
});
thread.start();
try {
thread.join();
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
while (true) {
System.out.println("Main thread is working");
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
但是最近有个UT测试的时候发现,假设A线程调用B线程的join方法,但是它根本不等待B线程结束就直接执行下面的程序了。
还有一件奇怪的事是Debug时却会等待。
最后的猜测是在执行join()这个线程时,B线程还没完全初始化好,所以A线程调用它的join方法就直接返回了。
如果在执行前调用Thread.sleep(100), 让A线程稍微等一下, 那程序就正常等待了。
----------------------------------------------------------------------------------------------------------------------------------------------
<<后续>>
刚刚仔细研究了一下,其实并不是Thread.join的问题。是因为这个Thread结束后又启动了第三个Thread.
第三个Thread会修改一些变量的值. 而我们的测试用例会测试这些变量。
因为join结束后,第三个线程还没有开始运行,所以测试会失败。表面上看起来好像是join方法的问题。
解决方案是在join方法后加Thread.sleep(100),而不是在之前加!