Java多线程工具CompletableFuture怎么使用


本文小编为大家详细介绍“Java多线程工具CompletableFuture怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java多线程工具CompletableFuture怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。写多线程程序的时候,可以使用Future从一个异步线程中拿到结果,但是如果使用过程中会发现一些问题:如果想要对Future的结果做进一步的操作,需要阻塞当前线程多个Future不能被链式的执行,每个Future的结果都是独立的,期望对一个Future的结果做另外一件异步的事情;没有异常处理策略,如果Future执行失败了,需要手动捕捉为了解决Future问题,JDK在1.8的时候给我们提供了一个好用的工具类CompletableFuture;它实现了Future和CompletionStage接口,针对Future的不足之处给出了相应的处理方式。在异步线程执行结束后可以自动回调我们新的处理逻辑,无需阻塞可以对多个异步任务进行编排,组合或者排序异常处理CompletableFuture的核心思想是将每个异步任务都可以看做一个步骤(CompletionStage),然后其他的异步任务可以根据这个步骤做一些想做的事情。CompletionStage定义了许多步骤处理的方法,功能非常强大,这里就只列一下日常中常用到的一些方法供大家参考。简单的使用方式异步执行,无需结果:异步执行,同时返回结果:thenRun: 不需要上一步的结果,直接直接新的操作thenAccept:获取上一步异步处理的内容,进行新的操作thenApply: 获取上一步的内容,然后产生新的内容所有加上Async后缀的,代表新的处理操作仍然是异步的。Async的操作都可以指定Executors进行处理当我们有两个回调在处理的时候,任何完成都可以使用,两者结果没有关系,那么使用acceptEither。两个异步线程谁先执行完成,用谁的结果,其余类型的方法也是如此。thenCombine当我们有两个CompletionStage时,需要对两个的结果进行整合处理,然后计算得出一个新的结果。thenCompose是对上一个CompletionStage的结果进免费云主机域名行处理,返回结果,并且返回类型必须是CompletionStage。thenCombine是得到第一个CompletionStage的结果,然后拿到当前的CompletionStage,两者的结果进行处理。thenAcceptBoth需要两个异步CompletableFuture的结果,两者都完成的时候,才进入thenAcceptBoth回调。当我们使用CompleteFuture进行链式调用的时候,多个异步回调中,如果有一个执行出现问题,那么接下来的回调都会停止,所以需要一种异常处理策略。exceptionallyexceptionally是当出现错误时,给我们机会进行恢复,自定义返回内容。handleexceptionally是只有发生异常时才会执行,而handle则是不管是否发生错误都会执行。需求为对某个表中特定条件的用户进行短信通知,但是短信用户有成百上千万,如果使用单线程读取效率会很慢。这个时候可以考虑使用多线程的方式进行读取;1、将读取任务拆分为多个不同的子任务,指定读取的偏移量和个数2、使用多线程进行批量读取3、进行业务逻辑处理,或者直接在读取完进行业务逻辑处理也是可以;在系统拆分比较细的时候,价格,优惠券,库存,商品详情等信息分散在不同的系统中,有时候需要同时获取商品的所有信息, 有时候可能只需要获取商品的部分信息。当然问题点在于要调用多个不同的系统,需要将RT降低下来,那么需要进行并发调用;如果不使用传入的线程池,大家用默认的线程池ForkJoinPoolthenRun用的默认和上一个任务使用相同的线程池thenRunAsync在执行新的任务的时候可以接受传入一个新的线程池,使用新的线程池执行任务;exceptionally是只有发生异常时才会执行,而handle则是不管是否发生错误都会执行。读到这里,这篇“Java多线程工具CompletableFuture怎么使用”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注百云主机行业资讯频道。

相关推荐: C++如何实现双目立体匹配Census算法

这篇“C++如何实现双目立体匹配Census算法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C++如何实现双目立体匹配Census算法”文章吧…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 03/30 19:09
下一篇 03/30 19:10

相关推荐