Java后端入职第三天,使用CompletableFuture优化查询接口

一、需求背景

相信大家入职到一个新公司(xinkeng),一般都会被分配去解决千古难题(caipigu),这些问题大概率很多不想去解决,并且代码很多复杂,各种套娃。领导为检验新人的能力,就会去让新人去解决这种问题,一方面可以了解业务代码,还能顺手把没人愿意做的事做了。但是,你做不好也没关系,大佬也会说,这个其实都是历史问题了,大家是不是有遇到这样奇葩新手工作呢?欢迎大家评论区讨论。今天给大家分享一个比较常见的问题,接口超时或者响应时间比较长怎么解决。

本文主要介绍,如何同个CompletableFuture异步编排,来解决分布多次查询,导致接口响应慢的问题。

二、CompletableFuture介绍与实战

1.为什么要用CompletableFuture呢?

大家都知道,多线程可以解决,多次查询第三方接口或者数据库耗时的问题?但是有种情况,可能就很难去解决了,比如一个异步调用可能会依赖另一个异步调用的执行结果。因为多线程一整个是一个任务,多线程可能就不好处理。所以Java8就推出了一个新的并发框架—CompletableFuture。可以参考书籍:《实战java高并发程序设计》 、《Java8实战》

2.CompletableFuture常用接口方法

1)CompletableFuture启动异步任务

    CompletableFuture提供四种静态方法来创建一个异步操作,可以自定义线程池,否没有传Executor则会使用默认线程池。

无返回值的:
    public static Comple

你可能感兴趣的:(Java后端开发,Java异步编排,多线程,接口优化)