thread 的join方法

join方法的底层执行? 看如测试用例: -> 

thread 的join方法_第1张图片

两个红色的框分别说明了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会被唤醒。
 

你可能感兴趣的:(并发,java,开发语言)