java中等待其他线程执行完成之后,再去执行别的方法
2018-01-25 15:29
645 查看
java主线程等待所有子线程执行完毕在执行,这个需求其实我们在工作中经常会用到,比如用户下单一个产品,后台会做一系列的处理,为了提高效率,每个处理都可以用一个线程来执行,所有处理完成了之后才会返回给用户下单成功。
我们通过以下的几种方法来解决:
一、使用Thread的join()等待所有的子线程执行完毕,主线程在执行,thread.join()把指定的线程加入到当前线程,可以将两个交替执行的线程合并为顺序执行的线程。比如在线程B中调用了线程A的Join()方法,直到线程A执行完毕后,才会继续执行线程B。
View Code
countDownLatch和cyclicBarrier区别:
countDownLatch只能使用一次,而CyclicBarrier方法可以使用reset()方法重置,所以CyclicBarrier方法可以能处理更为复杂的业务场景。
我曾经在网上看到一个关于countDownLatch和cyclicBarrier的形象比喻,就是在百米赛跑的比赛中若使用 countDownLatch的话冲过终点线一个人就给评委发送一个人的成绩,10个人比赛发送10次,如果用CyclicBarrier,则只在最后一个人冲过终点线的时候发送所有人的数据,仅仅发送一次,这就是区别。
我们通过以下的几种方法来解决:
一、使用Thread的join()等待所有的子线程执行完毕,主线程在执行,thread.join()把指定的线程加入到当前线程,可以将两个交替执行的线程合并为顺序执行的线程。比如在线程B中调用了线程A的Join()方法,直到线程A执行完毕后,才会继续执行线程B。
/** * * 处理一个业务逻辑的场景:当一组线程都执行完之后,在执行别的线程(后者要使用前者返回的结果) * @author Administrator * */ public class ThreadDemo3 { public static void main(String[] args) throws Exception { final CyclicBarrier barrier=new CyclicBarrier(5); //启用5个线程 for(int i=1;i<=5;i++){ new Thread(new Runnable(){ public void run(){ try { Thread.sleep(1000); } catch (Exception e) { e.printStackTrace(); } System.out.println("子线程执行!"); try { barrier.await();//到达屏障 } catch (InterruptedException | BrokenBarrierException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }).start(); } //主线程 barrier.await();//阻塞当前线程直到latch中数值为零才执行 System.out.println("主线程执行!"); } }
View Code
countDownLatch和cyclicBarrier区别:
countDownLatch只能使用一次,而CyclicBarrier方法可以使用reset()方法重置,所以CyclicBarrier方法可以能处理更为复杂的业务场景。
我曾经在网上看到一个关于countDownLatch和cyclicBarrier的形象比喻,就是在百米赛跑的比赛中若使用 countDownLatch的话冲过终点线一个人就给评委发送一个人的成绩,10个人比赛发送10次,如果用CyclicBarrier,则只在最后一个人冲过终点线的时候发送所有人的数据,仅仅发送一次,这就是区别。
相关文章推荐
- JAVA多线程—CountDownLatch-一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。
- java中等待一些线程执行完之后,再去执行别的方法(后者需要使用前者返回的结果)
- java中等待一些线程执行完之后,再去执行别的方法(后者需要使用前者返回的结果)
- Java后台执行Shell脚本, Java方法不用等待Shell程序执行完成并保证关掉Java程序Shell脚本正常运行
- 如何等待一个线程完成后才继续执行之后的操作
- Thread.join()方法实现main()方法等待所有子线程执行完成[base jdk8]
- JAVA主线程等待所有子线程执行完成后主线程再执行
- java线程池主线程等待子线程执行完成后再继续处理后面工作
- Java中等待提交线程池的所有线程执行完成
- CountDownLatch,一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。
- 等待线程池内线程执行完成的一种方法
- 子线程返回前,使循环暂停但不使主线程卡死的办法,等待子线程有返回了之后,才执行主线程下一步代码的方法
- Java后台执行Shell脚本, Java方法不用等待Shell程序执行完成并保证关掉Java程序Shell脚本正常运行
- java线程池主线程等待子线程执行完成后再继续处理后面工作
- CountDownLatch使用countDown方法来触发其他等待线程再执行的问题
- Java线程暂停一段时间之后继续执行的实现方法
- Java多线程执行,主程序等待其他线程执行完成
- CountDownLatch,一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待
- java并发编程学习:如何等待多个线程执行完成后再继续后续处理(synchronized、join、FutureTask、CyclicBarrier)
- java并发编程学习:如何等待多个线程执行完成后再继续后续处理(synchronized、join、FutureTask、CyclicBarrier)