Thread:主线程等待子线程执行完毕再执行解决办法

线程从启动到执行完毕,一般会有一些耗时操作,并不能像一般的程序语句,就能立马结束。如下代码:

package com.xxx.async;
public class WaitThreadDone {
	public static void main(String[] args) {
		Thread t1 = new Thread(new Runnable() {	
			@Override
			public void run() {
				try {
					System.out.println("thread "+Thread.currentThread().getName()+" start to run.");
					Thread.sleep(2000);
					System.out.println("thread " + Thread.currentThread().getName() + " done.");
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
		});		
		System.out.println("main start to run.");
		t1.start();
		System.out.println("main done.");
	}
}

这是一个典型的线程耗时操作,默认情况下,线程t1它不会立马结束,因此执行结果就是:

Thread:主线程等待子线程执行完毕再执行解决办法_第1张图片

我们希望主线程开始之后,等待子线程运行结束,主线程继续执行。

 Thread:主线程等待子线程执行完毕再执行解决办法_第2张图片

考虑子线程是一个耗时的阻塞操作,我们需要通过程序让子线程运行结束再执行主线程。这里给出如下几种解决办法:

①、t1.join()
②、while(t1.isAlive())
③、while(Thread.activeCount()>1)
④、CountDownLatch 

下面来看看具体的实现:

第一种办法:t1.start();后面接上t1.join()代码,如下:

Thread:主线程等待子线程执行完毕再执行解决办法_第3张图片

第二种办法:判断子线程是否还存活

Thread:主线程等待子线程执行完毕再执行解决办法_第4张图片

第三种办法:判断活跃的线程是否大于1

Thread:主线程等待子线程执行完毕再执行解决办法_第5张图片

第四种办法:通过同步工具类CountDownLatch实现 

 Thread:主线程等待子线程执行完毕再执行解决办法_第6张图片

这种办法需要CountDownLatch对象侵入线程run()方法的代码中。最终执行结果和前面几种解决办法一致。

 CountDownLatch通过await()方法阻塞主线程,等待其他线程运行结束,通过countDown()方法来释放锁,主线程开始执行。

总结:在这四种解决办法中,一、二两种办法需要知道线程的名字,当有很多线程同时执行的时候,有时候,我们是无法直观的知道每个线程的名字,这两个办法用的很少见。第四种办法在多线程的情况下也可以使用,就是需要设置CountDownLatch latch = new CountDownLatch(n),指定需要等待的线程数。第三种办法无需知道线程的名字和线程的数量,使用起来很直观。

你可能感兴趣的:(java)