通俗易懂地讲讲Java线程的Join方法

复制下面代码执行一下:

/**
* @author bruceliu
* @create 2019-06-01 23:12
* @description 当在主线程当中执行到t1.join()方法时,就认为主线程应该把执
行权让给t1
*/
public class JoinThread extends Thread{
    // 提供一个有参数的构造器,用于设置该线程的名字
    public JoinThread(String name) {
        super(name);
    } 
    // 重写run方法,定义线程执行体
    public void run() {
        for (int i = 0; i < 100; i++) {
            System.out.println(getName() + "" + i);
        }
    } 
    public static void main(String[] args) throws Exception {
        // 启动子线程
        new JoinThread("新线程------>").start();
        for (int i = 0; i < 100; i++) {
            if (i == 20) {
                JoinThread jt = new JoinThread("被Join的线程");
                jt.start();
                // main线程调用了jt线程的join()方法,main线程
                // 必须等jt执行结束才会向下执行
                jt.join();
            } 
            System.out.println(Thread.currentThread().getName() +
            "======>" + i);
        }
    }
}

结果分析: 上面程序中一共有3个线程,主方法开始时就启动了名为"新线程"的子线程,该子线程将会和main线程并发执行。当主线程的循环变量i等于20时启动了名为"被Join的线程"的线程,该线程不会和main线程并发执行。main线程必须等该线程执行结束后才可以向下执行。在名为"被Join的线程"的线程执行时,实际上只有2个子线程并发执行,而主线程处于等待状态。运行上面程序。从上面的运行结果可以看出,主线程执行到i=20时启动,并join了名为"被Join的线程"的线程,所以主线程将一直处于阻塞状态,直到名为"被Join的线程"的线程执行完成。
 

猜你喜欢

转载自blog.csdn.net/lezeqe/article/details/120527332