在日常开发中经常会遇到需要异步处理的逻辑,本文总结了常见的3种异步处理方式。
@Async注解
@Async注解是比较方便的实现方式,在使用过程中需要注意几点:
- 启用异步支持: 在启动类或配置类中开启异步,@EnableAsync
- 方法权限: 使用@Async注解的方法需要是public
- 返回值类型: 使用@Async注解的方法可以无返回值void,或者返回Future或CompletableFuture
- 不同类调用:@Async底层是通过AOP实现的,因此不支持同类调用,即调用异步方法的类和异步方法所在的类不能是同一个类,并且异步方法所在类需要被Spring管理(@Component,@Service,@Controller)
CompletableFuture
CompletableFuture支持同类异步调用,默认使用ForkJoinPool.commonPool()执行,共享线程池大小为cpu核数。
- 返回值类型: CompletableFuture泛型需要指定
- 阻塞调用: get(), join() 如果不指定超时时间,会阻塞等待方法执行完成返回结果
- 处理结果: thenApply()处理结果,thenAccept()消费结果,thenRun() 异步处理完成后逻辑,搭配join()等待所有异步处理及后续处理结束
线程池
可以灵活选择不同的线程池,并在任何场景下均可实现异步线程处理,但是需要监控线程池的资源消耗情况。
ExecutorService executorService = Executors.newFixedThreadPool(5);
executorService.submit();