关于SpringBoot使用@Async的总结 目录 SpringBoot使用@Async总结 如下方式会使@Async失效 SpringBoot实现异步(Async)接口 1. 启动类引入@EnableAsync注解 2. 建立异步任务类 3. 建立测试接口 SpringBoot使用@Async总结 注意事项: 如下方式会使@Async失效 1. 异步方法使用s
目录
- SpringBoot使用@Async总结
- 如下方式会使@Async失效
- SpringBoot实现异步(Async)接口
- 1. 启动类引入@EnableAsync注解
- 2. 建立异步任务类
- 3. 建立测试接口
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也成功执行了!

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。
本文标题为:关于SpringBoot使用@Async的总结
基础教程推荐
- Java中EnvironmentAware 接口的作用 2023-01-23
- springboot下使用shiro自定义filter的个人经验分享 2024-02-27
- JavaWeb 实现验证码功能(demo) 2024-04-14
- 深入理解约瑟夫环的数学优化方法 2024-03-07
- 是否适合从javabean类更新数据库? 2023-11-04
- 使用Java和WebSocket实现网页聊天室实例代码 2024-02-25
- 运用El表达式截取字符串/获取list的长度实例 2023-08-01
- Java+mysql实现学籍管理系统 2023-03-16
- JSP 动态树的实现 2023-12-17
- Java编写实现窗体程序显示日历 2023-01-02
