StackTc
StackTc
2018-01-27 11:52
采纳率: 61.9%
浏览 1.0k
已采纳

Thread.join方法的疑问

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;
            }
        }
    }


  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

5条回答 默认 最新

  • caozhy
    已采纳

    wait最终会转换成不同操作系统的进程阻塞的调用。也就是当线程失去cpu调度的时候,wait就会挂起,直到重新获得cpu。

    点赞 评论
  • CrazyBound
    CrazyBound 2018-01-27 11:52

    join和wait都是控制当前活动的线程。

    点赞 评论
  • oyljerry
    oyljerry 2018-01-27 12:38

    join,wait都是当前调用的线程阻塞

    点赞 评论
  • he_yun_c
    Kephn 2018-01-27 18:18

    实质上Thread整个对象都是存在于主线程栈里面的,真正的子线程是OS创建于内核里面的。但主线程可以通过执行join方法,使用isAlive去不断检查子线程的运行状态(条件量),没有退出就wait睡眠直到子线程状态为退出。

    点赞 评论
  • qq_28570941
    幽眠之森 2018-01-28 06:11

    你的代码少了启动子线程的逻辑,加上之后就可以看出来了
    子线程中价格睡眠,等待三秒,你会发现主线程中的打印语句是在子线程走完之后才打印

    点赞 评论

相关推荐