欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

关于SpringBoot使用@Async的总结

时间:2022-03-07 08:51:58|栏目:JAVA代码|点击:

SpringBoot使用@Async总结

注意事项:

如下方式会使@Async失效

1. 异步方法使用static修饰

2. 异步类没有使用@Component注解(或其他注解)导致spring无法扫描到异步类

3. 异步方法不能与异步方法在同一个类中

4. 类中需要使用@Autowired或@Resource等注解自动注入,不能自己手动new对象

5. 如果使用SpringBoot框架必须在启动类中增加@EnableAsync注解

6. 在Async 方法上标注@Transactional是没用的。 在Async 方法调用的方法上标注@Transactional 有效。

SpringBoot实现异步(Async)接口

1. 启动类引入@EnableAsync注解

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

2. 建立异步任务类

我们建了3个异步任务,分别延迟1s,2s,3s

@Component
public class AsyncTask {
    @Async
    public void task1() throws InterruptedException{
        long currentTimeMillis = System.currentTimeMillis();
        Thread.sleep(1000);
        long currentTimeMillis1 = System.currentTimeMillis();
        System.out.println("task1任务耗时:"+(currentTimeMillis1-currentTimeMillis)+"ms");
    }
    @Async
    public void task2() throws InterruptedException{
        long currentTimeMillis = System.currentTimeMillis();
        Thread.sleep(2000);
        long currentTimeMillis1 = System.currentTimeMillis();
        System.out.println("task2任务耗时:"+(currentTimeMillis1-currentTimeMillis)+"ms");
    }
    @Async
    public void task3() throws InterruptedException{
        long currentTimeMillis = System.currentTimeMillis();
        Thread.sleep(3000);
        long currentTimeMillis1 = System.currentTimeMillis();
        System.out.println("task3任务耗时:"+(currentTimeMillis1-currentTimeMillis)+"ms");
    }
}

3. 建立测试接口

@RestController
@RequestMapping("/test")
public class TestController {
    @Autowired
    private AsyncTask asyncTask;
    @RequestMapping("/async")
    public String doTask() throws InterruptedException{
        long currentTimeMillis = System.currentTimeMillis();
        asyncTask.task1();
        asyncTask.task2();
        asyncTask.task3();
        long currentTimeMillis1 = System.currentTimeMillis();
        return "task任务总耗时:"+(currentTimeMillis1-currentTimeMillis)+"ms";
    }
}

启动SpringBoot服务,访问/test/async接口,能看到任务耗时只有1s

在这里插入图片描述

查看控制台,发现异步task也成功执行了!

在这里插入图片描述

上一篇:带你了解Java数据结构和算法之2-3-4树

栏    目:JAVA代码

下一篇:Java的springcloud Sentinel是什么你知道吗

本文标题:关于SpringBoot使用@Async的总结

本文地址:http://www.codeinn.net/misctech/195451.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有