怎么获取10个线程的结果再返回
那么怎么获取子线程返回的值呢,我这里总结了三种方式:
- 主线程等待。
- Join方法等待。
- 实现Callable接口。
如何编程,使得主线程在跑完十个线程之后,再进行后续操作?
可以使用Callable来实现。因为实现线程有两种方式,实现Callable接口或者实现Runnable接口(至于继承Thread类,我觉得这个方式其实本质上还是实现了Runnable接口)。
用Runnable实现线程,我们一般是不知道线程有没有跑完的,除非经过特殊处理(如使用CountDownLatch)(ps:使用线程池的submit()可以返回一个future,调用其isDone()方法也可以确认其是否完成,2018-05-08修改)。
方法:但是如果使用Callable实现线程,我们是可以在call()方法中返回一个值,来确认此线程跑完了。
因此,我们可以在主线程中收集Callable的返回值,直到收集满了十个以后,再进行后续操作,没有收集满的话,就让主线程先休眠一会儿
方法2:用CountDownLatch实现在走完10个线程之后再进行操作。
CountDownLatch类:场景:就是某一个线程需要等待其它若干个线程完成某件事以后才能继续进行。
CyclicBarrier 类:实现多个线程一起启动的场景,就像赛跑一样,只要大家都准备好了,那就开始一起冲。
学海无涯 代码作伴