CompletableFuture实操,提升并发处理能力

  • 在Java8中,CompletableFuture提供了非常强大的Future的扩展功能,可以帮助我们简化异步编程的复杂性,并且提供了函数式编程的能力,可以通过回调的方式处理计算结果,也提供了转换和组合 CompletableFuture 的方法。
  • 它可能代表一个明确完成的Future,也有可能代表一个完成阶段( CompletionStage ),它支持在计算完成以后触发一些函数或执行某些动作。
  • 它实现了Future和CompletionStage接口

以下提供CompletableFuture实际操作代码

//方法调用
upload(urlList,state,uploadurl);

//这里的State可用其他数据类型替代如String
public List<State> upload(List<String> urlList,MultiState state, String uploadurl){

   int i=0;
  //使用newCachedThreadPool线程池,该线程池可以缓存60L的时间
   Executor executor = Executors.newCachedThreadPool();
//采用Stream流的形式进行处理
   List<CompletableFuture<State>> priceFuture = urlList.stream().map(url -> CompletableFuture
         .supplyAsync(() ->  captureRemoteData(url,state,uploadurl,i) ,executor))
         .collect(Collectors.toList());
   return priceFuture.stream().map(CompletableFuture::join).col
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值