介绍:接下来我会把学习阶段学到的框架等知识点进行整合,每一次整合是在前一章的基础上进行的,所以后面的整合不会重复放前面的代码。每次的demo我放在结尾,本次是接着上一章的内容延续的,只增加新增的或者修改的代码。
在上一章整合了线程池,并开启了线程池状态的打印查看。本章将整合异步调用并获取异步调用的返回值。
场景:一个接口里面要处理很多业务,响应很慢。可以将这些业务写成异步任务。
ps:异步调用的方法返回值类型是Future类,Future是专门接收异步响应的类
相比上一章,目录结构没有新增。
第一步:新建异步任务
注意返回值是Future类,加上Async注解。
注意开启异步监控注解,@EnableAsync//开启异步调用,可以在启动类上加,上一章的整合已经在线程池的配置类上面加了该注解,所以不需要加了。
第二步:在controller里面新建一个接口与用于测试
从上面可以得知,若不是异步请求,该请求会花费4000。
第三步:演示
可以看到,耗时3019,并且两个异步任务也是同时执行的,不是一个执行完了再执行的第二个。并且从Future获取值也获取到了,通过future的get方法。
踩坑:一开始我将异步任务也写在controller里面的,结果调用接口,并没有实现异步。小白一枚,刚开始学习,不太懂,有大佬愿意在评论区点拨一番,不胜感激。
本期整合到此完毕,接下来会继续更新加强整合,尽情期待。
访问地址:http://localhost:8087/swagger-ui.html或者http://localhost:8087/doc.html