join方法的底层执行? 看如测试用例: ->
两个红色的框分别说明了sleep方法前后test01的状态,这个不是重点,只是一个验证而已。
重要的是test02的状态,调用join方法后,test02变成了WAITING状态,为什么?
public final synchronized void join(long millis) throws InterruptedException {
long base = System.currentTimeMillis();
long now = 0;
if (millis < 0) {
throw new IllegalArgumentException("timeout value is negative");
}
if (millis == 0) {
while (isAlive()) {
//注意这里:join方法的底层还是调用了wait()
wait(0);
}
} else {
while (isAlive()) {
long delay = millis - now;
if (delay <= 0) {
break;
}
wait(delay);
now = System.currentTimeMillis() - base;
}
}
}
join方法加了锁,锁的是谁?test01,谁持有锁?test02,搞清楚这两个地方后,那么:
我们可以看出:是test02线程在调用 join() -> wait(), 所以test02会进入WAITING状态。直到test01执行完,自动调用Thread.exist()方法,在exist()方法中,test02会被唤醒。