Thread的API介绍

  • Post author:
  • Post category:其他


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 版权协议,转载请附上原文出处链接和本声明。