内容简介:要使用更详细的配置说明,可以参考:(1)无入参无返回值方法
要使用 @Async
,首先需要使用 @EnableAsync
注解开启 Spring Boot 中的异步特性。
@Configuration @EnableAsync public class AppConfig { } 复制代码
更详细的配置说明,可以参考:
AsyncConfigurer
@Async
注解
支持的用法
(1)无入参无返回值方法
您可以用 @Async
注解修饰方法,这表明这个方法是异步方式调用。换句话说,程序在调用此方法时会立即返回,而方法的实际执行发生在已提交给 Spring TaskExecutor
的任务中。在最简单的情况下,您可以将注解应用于返回 void 的方法,如以下示例所示:
@Async void doSomething() { // this will be executed asynchronously } 复制代码
(2)有入参无返回值方法
与使用 @Scheduled
注释注释的方法不同,这些方法可以指定参数,因为它们在运行时由调用者以“正常”方式调用,而不是由容器管理的调度任务调用。例如,以下代码是 @Async
注解的合法应用:
@Async void doSomething(String s) { // this will be executed asynchronously } 复制代码
(3)有入参有返回值方法
甚至可以异步调用返回值的方法。但是,这些方法需要具有 Future
类型的返回值。这仍然提供了异步执行的好处,以便调用者可以在调用 Future
上的 get()
之前执行其他任务。以下示例显示如何在返回值的方法上使用 @Async
:
@Async Future<String> returnSomething(int i) { // this will be executed asynchronously } 复制代码
不支持的用法
@Async
不能与生命周期回调一起使用,例如 @PostConstruct
。
要异步初始化 Spring bean,必须使用单独的初始化 Spring bean,然后在目标上调用 @Async
带注释的方法,如以下示例所示:
public class SampleBeanImpl implements SampleBean { @Async void doSomething() { // ... } } public class SampleBeanInitializer { private final SampleBean bean; public SampleBeanInitializer(SampleBean bean) { this.bean = bean; } @PostConstruct public void initialize() { bean.doSomething(); } } 复制代码
明确指定执行器
默认情况下,在方法上指定 @Async
时,使用的执行器是在启用异步支持时配置的执行器,即如果使用 XML 或 AsyncConfigurer
实现(如果有),则为“annotation-driven”元素。但是,如果需要指示在执行给定方法时应使用默认值以外的执行器,则可以使用 @Async
注解的 value 属性。以下示例显示了如何执行此操作:
@Async("otherExecutor") void doSomething(String s) { // this will be executed asynchronously by "otherExecutor" } 复制代码
在这种情况下,“otherExecutor”可以是 Spring 容器中任何 Executor bean 的名称,也可以是与任何 Executor 关联的限定符的名称(例如,使用 <qualifier>
元素或 Spring 的 @Qualifier
注释指定) )。
管理 @Async
的异常
当 @Async
方法的返回值类型为 Future
型时,很容易管理在方法执行期间抛出的异常,因为在调用 get
结果时会抛出此异常。但是,对于返回值类型为 void 型的方法,异常不会被捕获且无法传输。您可以提供 AsyncUncaughtExceptionHandler
来处理此类异常。以下示例显示了如何执行此操作:
public class MyAsyncUncaughtExceptionHandler implements AsyncUncaughtExceptionHandler { @Override public void handleUncaughtException(Throwable ex, Method method, Object... params) { // handle exception } } 复制代码
默认情况下,仅记录异常。您可以使用 AsyncConfigurer
或 <task:annotation-driven />
XML元素定义自定义 AsyncUncaughtExceptionHandler
。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 原生JS发送异步数据请求
- 四步轻松实现ajax发送异步请求
- 异步的发展,顺手学会怎么处理多请求
- 关于ajax异步请求的一个细节问题
- easyhttp v1.1发布,新增异步并发请求
- 如何优化Android异步请求服务器数据?
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。