Java多线程:对于Thread.join()的理解

以前一直搞不明白Thread当中的join到底是怎么用的,今天自己写了个小例子过后总算是有点眉目。

先来看JDK官方文档对于join是怎么描述的:

// 等待该线程终止。
public final void join() throws InterruptedException

还有几个重载的方法就不多赘述,这样描述其实挺让人难懂的,所以还是看例子吧

package concurrent;

import java.util.concurrent.TimeUnit;

public class ThreadJoinDemo {

    public static void main(String[] args) {

        final Thread t1 = new Thread(() -> {
            try {
            	//等待10s
                TimeUnit.SECONDS.sleep(10);
                System.out.println("T1 is done");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        });

        final Thread t2 = new Thread(() -> {
            try {
            	//等待5s
                TimeUnit.SECONDS.sleep(5);
                //等待t1执行结束
                t1.join();
                System.out.println("T2 is done");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        });

        t1.start();
        t2.start();
    }
}
/*
Output:
T1 is done
T2 is done
*/
```
可以看到,t2线程本身比t1执行的时间要少,但是需要先等待t1执行完毕后,t1.join()才会停止对t2的阻塞,使t2可以继续执行下面的语句。

猜你喜欢

转载自blog.csdn.net/qq_41989109/article/details/105887069