join:等待当前线程执行完成之后,再执行接下来的语句,如下面的例子所示,在t1线程启动完之后,调用t1.join()的方法,那么会在这里阻塞住,直到t1线程执行完之后,才会继续执行下面的语句
public class RunnableJob implements Runnable{
@Override
public void run() {
try {
thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void main(String[] args) throws InterruptedException {
RunnableJob runnableJob = new RunnableJob();
Thread t1 = new Thread(runnableJob);
t1.start();
t1.join();
System.out.println("end");
}
}
join方法可以使线程之间的异步执行变成同步执行,如下示例清单2所示,t2线程会在t1线程执行完之后才会启动
示例清单2
t1.start();
t1.join();
t2.start();
也可以完成如下这样的任务,让多个线程先完成,之后再执行某个操作,如示例清单3:如果没有使用join方法,那么线程与System.out.println(“end”);之间的执行顺序是未知的,使用join之后,虽然t[0]~t[4]的执行顺序未知,但可以确定,这5个线程一定比System.out.println(“end”);先执行
示例清单:
Thread[] t = new Thread[5];
for(int i = 0; i < 5; i++){
t[i] = new Thread(runnableJob);
t[i].start();
}
//使用join方法来控制线程的同步执行
for(int i = 0; i < t.length; i++){
t[i].join();
}
System.out.println("end");
版权声明:本文为sujz12345原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。