Thread类中的join()方法源码以下: web
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;
}
}
}
开始看这段源码的时候不明白,假设一个线程对象在main中调用join如:
public static void main(String[] args) throws InterruptedException {
System.out.println("---main----");
ThreadA threadA =new ThreadA();
threadA.start();
threadA.join();
System.out.println("---main---");
}
问题1:那么在源码中调用wait方法应该是thraedA等待,但事实倒是main方法等待了
缘由是wait方法是object类中的方法,调用该方法是让得到当前对象锁的线程等待,而在threadA.join()时,是在主线程中进行调用了,主线程得到join方法上的对象锁。
public final synchronized void join(long millis)
问题2:为何isAlive判断是的ThreadA线程是否存活,
public final native boolean isAlive();
由于这个方法调用的是ThreadA从Thread类中继承的本地方法,是一种普通的方法调用,因此它判断的是ThreadA线程是否还存活。