ForkJoin框架简单使用

本文介绍了在接口调用多个外部服务时如何通过ForkJoin框架、线程池和Callable来并行处理,以减少总响应时间。强调了在业务无关联性的情况下,可以利用多线程优化,同时提醒注意ForkJoin的使用要点,如合理拆分任务和避免阻塞,以及线程池和CountDownLatch的配合使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

场景描述

设想这样一个场景,在一个接口中,需要通过http的方式调用多个外部接口,而且可能存在某几个接口非常耗时的情况,这么一来,对当前接口来说,由于是串行的执行,忽略本地接口的耗时,总的耗时就可以大致估算为调用的多个外部接口响应时间之和,这还是在没有考虑网络延时等其他外部因素作用下

这种场景在业务中随处可见,也是程序员考虑的优化接口响应时间的入手点

解决思路

当存在上述的情况,我们很自然的联想到能否采用多线程的方式,将不同的http接口调用放到不同的线程中执行,最后再拿到各自的执行结果呢?这里有两种情况需要考虑

1. 各个http接口的调用结果是否有业务上的关联性
2. 使用哪种方式合并各自接口的返回结果

第一点是非常关键的,也是能否考虑使用多线程优化的重要一点,假设各个接口具备前后业务上的逻辑关系,第二个调用的接口的参数来自于第一个接口的返回结果,这个显然不行

假如不存在业务上的关联性,就可以考虑使用多线程的方式进行优化,但实现方式也是有很多种,具体使用哪种呢?下面介绍几种方式

问题复现

在当前的一个接口中,需要分别调用另外两个服务的接口,然后在本地接口中进行数据集合并

@Service
public class UserService {
   
   

    @Aut
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小码农叔叔

谢谢鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值