一个线程的输入可能非常依赖于另外一个或者多个线程的输出,此时这个线程就需要等待依赖线程执行完毕,才能继续执行。JDK 提供了 join()操作来实现这个功能。
public final void join()
public final synchronized void join(long millis)
第一个 join()方法表示无线等待,他会一直阻塞当前线程,直到目标线程执行完毕。第二个方法给出了一个最大的等待时间,如果超过给定的时间目标线程还在执行,当前线程也会因为“等不及了”,而继续往下执行。
/**
* Created by zhangjianghong on 2017/8/1.
*/
public class JoinMain {
public volatile static int i = 0;
public static class AddThread extends Thread{
@Override
public void run() {
for (i = 0; i < 10000; i++);
}
}
public static void main(String[] args) throws InterruptedException {
AddThread addThread = new AddThread();
addThread.start();
addThread.join();
System.out.println(i);
}
}
如果没有addThread.join(); 程序运行结果可能是 0 或者一个小于10000 的数字,是因为AddThread 线程还没有跑结束,主线程就结束了,当加了join()方法时,表示主线程等待AddThread线程执行结束后再继续执行,所以它的结果肯定是10000。