复制下面代码执行一下:
/**
* @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的线程"的线程执行完成。