如果一个线程A执行了thread.join()语句,其含义是:当前线程A等待thread线程终止之后才从thread.join()返回。
经典面试题:现在有T1、T2、T3
三个线程,你怎样保证T2
在T1
执行完后执行,T3
在T2
执行完后执行?
public static void main(String[] args) {
// 初始化线程t1,由于后续有匿名内部类调用这个对象,需要用final修饰
final Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
System.out.println("t1 is running");
}
});
// 初始化线程t2,由于后续有匿名内部类调用这个对象,需要用final修饰
final Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
try {
// t1调用join方法,t2会等待t1运行完之后才会开始执行后续代码
t1.join();
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println("t2 is running");
}
}
});
// 初始化线程t3
Thread t3 = new Thread(new Runnable() {
@Override
public void run() {
try {
// t2调用join方法,t3会等待t2运行完之后才会开始执行后续代码
t2.join();
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
System.out.println("t3 is running");
}
}
});
// 依次启动3个线程
t1.start();
t2.start();
t3.start();
}
输出结果:
t1 is running
t2 is running
t3 is running
解释下:t1.start(),t2.start()的2中情况:
(1)t1.start(),t1很快调用run()执行完,输出“t1 is running”。接着t2线程启动执行t2的run()方法,t2线程执行到t1.join(),其含义是:t2等待t1终止之后才从t1.join()返回。在这里t1已经执行完了,所以t2线程执行finally语句输出“t2 is running”
(2)t1.start(),t1执行很慢,还没有输出“t1 is running”。接着t2线程启动执行t2的run()方法,t2线程执行到t1.join(),其含义是:t2等待t1终止之后才从t1.join()返回,在这里t2慢慢等t1执行完(也就是等t1输出“t1 is running”)。等到t1输出“t1 is running”执行完,t2才返回,接着t2线程执行finally语句输出“t2 is running”
t1.start(),t2.start(),t3.start()是同样的道理。