java中等待一些线程执行完之后,再去执行别的方法(后者需要使用前者返回的结果)
来源:互联网 发布:软件安装管理器 知乎 编辑:程序博客网 时间:2024/06/06 05:29
Java主线程等待所有子线程执行完毕在执行,这个需求其实我们在工作中经常会用到,比如用户下单一个产品,后台会做一系列的处理,为了提高效率,每个处理都可以用一个线程来执行,所有处理完成了之后才会返回给用户下单成功。
我们通过以下的几种方法来解决:
一、用sleep方法,让主线程睡眠一段时间,当然这个睡眠时间是主观的时间,是我们自己定的,这个方法不推荐,但是在这里还是写一下,毕竟是解决方法
二、使用Thread的join()等待所有的子线程执行完毕,主线程在执行,thread.join()把指定的线程加入到当前线程,可以将两个交替执行的线程合并为顺序执行的线程。比如在线程B中调用了线程A的Join()方法,直到线程A执行完毕后,才会继续执行线程B。
/** * * 处理一个业务逻辑的场景:当一组线程都执行完之后,在执行别的线程(后者要使用前者返回的结果) * @author Administrator * */public class ThreadDemo {public static void main(String[] args) throws InterruptedException {Vector<Thread> vectors=new Vector<Thread>();//启用5个线程for(int i=1;i<=5;i++){Thread childrenThread=new Thread(new Runnable(){ public void run(){ try {Thread.sleep(1000);} catch (Exception e) {e.printStackTrace();} System.out.println("子线程执行!"); }});vectors.add(childrenThread);childrenThread.start();}//主线程for(Thread thread : vectors){thread.join(); //使用join来保证childrenThread的5个线程都执行完后,才执行主线程}System.out.println("主线程执行!");}}三、下面结合这个问题我介绍一些并发包里非常有用的并发工具类,等待多线程完成的CountDownLatch
/** * * 处理一个业务逻辑的场景:当一组线程都执行完之后,在执行别的线程(后者要使用前者返回的结果) * @author Administrator * */public class ThreadDemo2 {public static void main(String[] args) throws InterruptedException {final CountDownLatch latch= new CountDownLatch(5);//使用java并发库concurrent//启用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("子线程执行!"); latch.countDown();//让latch中的数值减一 }}).start();}//主线程latch.await();//阻塞当前线程直到latch中数值为零才执行System.out.println("主线程执行!");}}在这里说明一点,countDownLatch不可能重新初始化或者修改CountDownLatch对象内部计数器的值,一个线程调用countdown方法happen-before另外一个线程调用await方法
四、同步屏障CyclicBarrier
/** * * 处理一个业务逻辑的场景:当一组线程都执行完之后,在执行别的线程(后者要使用前者返回的结果) * @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 blocke.printStackTrace();} }}).start();}//主线程barrier.await();//阻塞当前线程直到latch中数值为零才执行System.out.println("主线程执行!");}}
写到这里大家不免有些疑问,countDownLatch和cyclicBarrier有什么区别呢,他们的区别:countDownLatch只能使用一次,而CyclicBarrier方法可以使用reset()方法重置,所以CyclicBarrier方法可以能处理更为复杂的业务场景。
我曾经在网上看到一个关于countDownLatch和cyclicBarrier的形象比喻,就是在百米赛跑的比赛中若使用 countDownLatch的话冲过终点线一个人就给评委发送一个人的成绩,10个人比赛发送10次,如果用CyclicBarrier,则只在最后一个人冲过终点线的时候发送所有人的数据,仅仅发送一次,这就是区别。
阅读全文
0 1
- java中等待一些线程执行完之后,再去执行别的方法(后者需要使用前者返回的结果)
- 关于同一个函数,在多个js中有,在html调用这个函数的时候,是后者覆盖掉前者,还是执行完前者,再执行后者?
- Java中等待线程执行完毕
- 如何得到线程执行完之后返回的结果
- 多线程执行完后主程序再执行(包括需要子线程返回结果)
- java 使用Callable和Future返回线程执行的结果
- java中等待所有线程都执行结束
- Java中等待所有线程都执行结束
- Java中等待提交线程池的所有线程执行完成
- 线程池等待一定数目的线程执行完毕之后返回结果
- 当多线程执行需要返回执行结果的实现方式
- Java线程暂停一段时间之后继续执行的实现方法
- 如何在java中获取线程异步执行之后的结果
- Callable接口实现线程执行结果的返回
- python 写一个Mythread能返回线程执行的结果
- 关于在子线程中在run方法执行完之后通知主线程进行操作的方法。(Toast在子线程中无法使用)
- 关于使用CyclicBarrier使主线程等待子线程执行完之后再向下执行的问题
- shell中等待其他程序执行完毕
- OpenCV3 Python语言实现 笔记1
- GalaxyOJ-687 (离散化)
- 递推问题之“佐罗”的烦恼
- POJ1087:A Plug for UNIX(最大流)
- 零阶矩、一阶矩、二阶矩、三阶矩
- java中等待一些线程执行完之后,再去执行别的方法(后者需要使用前者返回的结果)
- Android系列之手机多点触摸画圆
- 二进制、八进制、十进制、十六进制之间的转换
- 字符串转二进制
- 1019. General Palindromic Number (20)
- GetMessage
- LightOJ
- 欢迎使用CSDN-markdown编辑器
- Struts2获取request、session、application的三种方法