异步执行
- 1.基于@Async注解的方式
- 在异步的方法上加 @Async注解,调用接口后
- 基于@Async注解的方式优缺点:
- 2.使用 CompletableFuture 实现异步任务
- 在实现类中创建CompletableFuture 类型的方法
- 优缺点:
- 3.使用 TaskExecutor 实现异步任务
- 优缺点:
1.基于@Async注解的方式
@Async 注解是 Spring 提供的一种轻量级异步方法实现方式,它可以标记在方法上,用来告诉 Spring 这个方法是一个异步方法,Spring 会将这个方法的执行放在异步线程中进行。使用 @Async 注解需要满足以下条件:
1.需要在 Spring Boot 主类上添加 @EnableAsync 注解启用异步功能;
2.需要在异步方法上添加 @Async 注解。
在异步的方法上加 @Async注解,调用接口后
基于@Async注解的方式优缺点:
基于注解的方式
优点:
1.简单易用,只需要在方法上添加@Async注解即可。
2.依赖Spring框架,集成度高,可以与其他Spring组件无缝协作。
缺点:
1.方法必须是public,否则异步执行无效。
2.不能直接获取异步执行结果,需要使用Future或CompletableFuture等类型。
2.使用 CompletableFuture 实现异步任务
CompletableFuture 是 Java 8 新增的一个异步编程工具,它可以方便地实现异步任务。使用 CompletableFuture 需要满足以下条件:
1.异步任务的返回值类型必须是 CompletableFuture 类型;
2.在异步任务中使用 CompletableFuture.supplyAsync() 或 CompletableFuture.runAsync() 方法来创建异步任务;
3.在主线程中使用 CompletableFuture.get() 方法获取异步任务的返回结果。
在实现类中创建CompletableFuture 类型的方法
结果与上面一样都能保证异步执行
优缺点:
实现AsyncConfigurer接口的方式
优点:
更加灵活,可以配置线程池等异步执行的相关参数。
可以通过实现AsyncUncaughtExceptionHandler接口来捕获异步执行中的异常。
缺点:
需要在代码中手动创建线程池,相对比较繁琐。
方法必须返回Future或CompletableFuture等类型,否则无法异步执行。
3.使用 TaskExecutor 实现异步任务
TaskExecutor 是 Spring 提供的一个接口,它定义了一个方法 execute(),用来执行异步任务。使用 TaskExecutor 需要满足以下条件:
1.需要在 Spring 配置文件中配置一个 TaskExecutor 实例;
2.在异步方法中调用 TaskExecutor 实例的 execute() 方法来执行异步任务。
先写一个配置类,配置一个 TaskExecutor 实例
package com.peng.config;
import org.springframework.aop.interceptor.AsyncUncaughtExceptionHandler;
import org.springframework.aop.interceptor.SimpleAsyncUncaughtExceptionHandler;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.task.TaskExecutor;
import org.springframework.scheduling.annotation.AsyncConfigurer;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import java.util.concurrent.Executor;
@Configuration
@EnableAsync
public class AsyncConfig implements AsyncConfigurer {
@Bean(name = "asyncExecutor")
public TaskExecutor asyncExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(10);
executor.setMaxPoolSize(20);
executor.setQueueCapacity(100);
executor.setThreadNamePrefix("async-");
executor.initialize();
return executor;
}
@Override
public Executor getAsyncExecutor() {
return asyncExecutor();
}
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return new SimpleAsyncUncaughtExceptionHandler();
}
}
实现类中调用execute进行实现
最后结果与上相同,可正常执行异步
优缺点:
基于ThreadPoolTaskExecutor的方式
优点:
基于Spring内置的线程池实现,省去手动配置线程池的繁琐过程。
可以设置队列容量和拒绝策略,控制异步任务的执行顺序和并发量。
缺点:
略微复杂,需要手动创建ThreadPoolTaskExecutor实例,并将其注入到需要异步执行的方法中。
参考https://mp.weixin.qq.com/s/I_3GJfZgz21DnuXmrJEzgg