Spring使用异步注解@Async正确姿势

简介: Spring使用异步注解@Async正确姿势,异步任务,spring boot

最近项目中用到了该注解,对其查找线程池的顺序比较困惑,查阅资料简单整理在此。

注意的点
1、 必须用在public方法上 2、 在某异步方法的同一个类的其他方法调用此异步方法无效

Spring的异步配置
要激活Spring的异步行为,可以为配置类添加@EnableAsync注解。

@EnableAsync
@SpringBootApplication
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

@EnableAsync 检测@Async注解。

基本用法
该注解用到需要用其他线程处理任务的方法上。

不带任何返回值的用法

@Override
@Async
public void createUserWithDefaultExecutor(){
    //SimpleAsyncTaskExecutor
    System.out.println("Currently Executing thread name - " + Thread.currentThread().getName());
    System.out.println("User created with default executor");
}

默认Spring会搜索容器中唯一的TaskExecutor类型的Bean,或名为taskExecutor的Executor类型的bean。
如果两者都找不到,一个SimpleAsyncTaskExecutor任务执行器将被用来处理该注解的任务。

带返回值的用法

@Override
@Async
public Future createAndReturnUser() {
    System.out.println("Currently Executing thread name - " + Thread.currentThread().getName());
    try {
        User user = new User();
        user.setFirstName("John");
        user.setLastName("Doe");
        user.setGender("Male");
        Thread.sleep(5000);
        return new AsyncResult(user);
    } catch (InterruptedException e) {
        System.out.println(e.getMessage());
    }
    return null;
}

下面是测试方法:

@Test
public void createAndReturnUserTest() throws ExecutionException, InterruptedException {
    System.out.println("Current Thread in test class " + Thread.currentThread().getName());
    long startTime = System.currentTimeMillis();
    Future futureUser = userService.createAndReturnUser();
    futureUser.get();
    assertTrue((System.currentTimeMillis() - startTime) >= 5000);
}

定义范例

Spring默认用SimpleAsyncTaskExecutor来处理@Async注解的任务。
我们还可以利用参考下面的示例来自定义方法级别的处理器。

@Bean(name = "threadPoolExecutor")
public Executor getAsyncExecutor() {
    ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
    executor.setCorePoolSize(7);
    executor.setMaxPoolSize(42);
    executor.setQueueCapacity(11);
    executor.setThreadNamePrefix("threadPoolExecutor-");
    executor.initialize();
    return executor;
}
相关文章
|
1月前
|
Java 开发者 Spring
【SpringBoot 异步魔法】@Async 注解:揭秘 SpringBoot 中异步方法的终极奥秘!
【8月更文挑战第25天】异步编程对于提升软件应用的性能至关重要,尤其是在高并发环境下。Spring Boot 通过 `@Async` 注解简化了异步方法的实现。本文详细介绍了 `@Async` 的基本用法及配置步骤,并提供了示例代码展示如何在 Spring Boot 项目中创建与管理异步任务,包括自定义线程池、使用 `CompletableFuture` 处理结果及异常情况,帮助开发者更好地理解和运用这一关键特性。
113 1
|
29天前
|
缓存 Java 数据库连接
Spring Boot奇迹时刻:@PostConstruct注解如何成为应用初始化的关键先生?
【8月更文挑战第29天】作为一名Java开发工程师,我一直对Spring Boot的便捷性和灵活性着迷。本文将深入探讨@PostConstruct注解在Spring Boot中的应用场景,展示其在资源加载、数据初始化及第三方库初始化等方面的作用。
49 0
|
14天前
|
Java 数据库连接 数据格式
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
IOC/DI配置管理DruidDataSource和properties、核心容器的创建、获取bean的方式、spring注解开发、注解开发管理第三方bean、Spring整合Mybatis和Junit
【Java笔记+踩坑】Spring基础2——IOC,DI注解开发、整合Mybatis,Junit
|
29天前
|
监控 Java API
Spring Boot中的异步革命:构建高性能的现代Web应用
【8月更文挑战第29天】Spring Boot 是一个简化 Spring 应用开发与部署的框架。异步任务处理通过后台线程执行耗时操作,提升用户体验和系统并发能力。要在 Spring Boot 中启用异步任务,需在配置类上添加 `@EnableAsync` 注解,并定义一个自定义的 `ThreadPoolTaskExecutor` 或使用默认线程池。通过 `@Async` 注解的方法将在异步线程中执行。异步任务适用于发送电子邮件、数据处理、外部 API 调用和定时任务等场景。最佳实践中应注意正确配置线程池、处理返回值和异常、以及监控任务状态,确保系统的稳定性和健壮性。
31 0
|
29天前
|
监控 安全 Java
【开发者必备】Spring Boot中自定义注解与处理器的神奇魔力:一键解锁代码新高度!
【8月更文挑战第29天】本文介绍如何在Spring Boot中利用自定义注解与处理器增强应用功能。通过定义如`@CustomProcessor`注解并结合`BeanPostProcessor`实现特定逻辑处理,如业务逻辑封装、配置管理及元数据分析等,从而提升代码整洁度与可维护性。文章详细展示了从注解定义、处理器编写到实际应用的具体步骤,并提供了实战案例,帮助开发者更好地理解和运用这一强大特性,以实现代码的高效组织与优化。
48 0
|
29天前
|
Java 开发者 Spring
Spring Boot大法好:解耦、隔离、异步,让代码‘活’起来,性能飙升的秘密武器!
【8月更文挑战第29天】解耦、隔离与异步是Spring Boot中的关键设计原则,能大幅提升软件的可维护性、扩展性和性能。本文通过示例代码详细探讨了这些原则的应用:依赖注入和面向接口编程实现解耦;模块化设计与配置文件实现隔离;`@Async`注解和`CompletableFuture`实现异步处理。综合运用这些原则,可以显著提升软件质量和性能,使系统更加健壮、灵活和高效。
22 0
|
4月前
|
Java API Spring
Spring容器如何使用一个注解来指定一个类型为配置类型
Spring容器如何使用一个注解来指定一个类型为配置类型
46 0
|
3月前
|
XML Java 数据格式
Spring5系列学习文章分享---第三篇(AOP概念+原理+动态代理+术语+Aspect+操作案例(注解与配置方式))
Spring5系列学习文章分享---第三篇(AOP概念+原理+动态代理+术语+Aspect+操作案例(注解与配置方式))
35 0
|
3月前
|
Java Spring
spring基于注解配置数据源
spring基于注解配置数据源
|
XML Java 数据格式
spring ioc中的一些常用annotation注解配置
spring ioc中的一些常用annotation注解配置