join的方法是使主线程阻塞,可是从源码看哪里看出是主线程阻塞而不是子线程呢?
wait()哪里说命了是主线程。还有isAlive哪里说明了是判断主线程的存活状态。
public static void main(String[] agrs){
Thread a = new Thread();
a.join();
System.out.pring("最后执行");
}
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()) {
wait(0);
}
} else {
while (isAlive()) {
long delay = millis - now;
if (delay <= 0) {
break;
}
wait(delay);
now = System.currentTimeMillis() - base;
}
}
}
wait最终会转换成不同操作系统的进程阻塞的调用。也就是当线程失去cpu调度的时候,wait就会挂起,直到重新获得cpu。
join和wait都是控制当前活动的线程。
join,wait都是当前调用的线程阻塞
实质上Thread整个对象都是存在于主线程栈里面的,真正的子线程是OS创建于内核里面的。但主线程可以通过执行join方法,使用isAlive去不断检查子线程的运行状态(条件量),没有退出就wait睡眠直到子线程状态为退出。
你的代码少了启动子线程的逻辑,加上之后就可以看出来了
子线程中价格睡眠,等待三秒,你会发现主线程中的打印语句是在子线程走完之后才打印