搜集所有子线程结果给主线程然后再执行剩下逻辑的几种方式

标题太长了,有点类似于 fork/join 的思想,但是对Java不是很了解,所以不知道自己理解的对不对,然后标题就写成这样了。
场景描述:
以前一个朋友给我说,他要同时请求三个接口,然后三个接口数据都得到后,再整理到一个集合中去,然后显示出来。当时我说了一种思路,就是设置一个int i = 3的变量值,当每一个接口完成后,这个值就减一,然后再检查这个值的大小,直到这个值为0,然后再整理数据,返回主线程进行显示。现在不得不说这种方式比较low….
后来经验增长后,知道有以下方案可以完成:
1、使用 CountDownLatch(计数锁,这个词是我自己理解翻译 的…) 类完成目标
2、使用 CyclicBarrier(同步屏障) 类完成目标
3、使用 Semaphore(信号量) 类完成
4、使用 CompletableFuture 类完成(java 8提供)
前三种可以参考以下链接进行了解:
http://www.cnblogs.com/dolphin0520/p/3920397.html
第四种可以参考下面链接进行了解:
https://www.jianshu.com/p/4897ccdcb278

猜你喜欢

转载自blog.csdn.net/Mr_Tony/article/details/78969295