观看源码可以了解到,Thread的join方法利用的是等待/唤醒机制实现的。join中的代码片段:
if (millis == 0) {
while (isAlive()) {
wait(0);
}
} else {
while (isAlive()) {
long delay = millis - now;
if (delay <= 0) {
break;
}
wait(delay);
now = System.currentTimeMillis() - base;
}
}
A线程中调用B线程的join方法的时候,先获取当前B线程对象的锁,然后判断B线程是否存活,如果B存活则调用wait方法等待,A线程进入超时等待状态,A线程释放锁,直到B线程结束才继续运行。
一点疑问:
既然A调用B线程的join,那为什么A会被阻塞?
因为,A中调用B线程的join的时候,当前运行的线程是A而不是B,这个时候可以这么理解,把join看成其它方法比如test方法,A调用B的test的时候B就是一个普通对象,并不是说B线程去执行join方法,还是A线程在执行B的join方法,然后再去调用wait方法,从而A线程进入等待状态。