关于SpringBoot使用@Async的总结

网友投稿 323 2022-09-06


关于SpringBoot使用@Async的总结

目录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 InterruptedExceptioTyakoJn{

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("tashttp://k3任务耗时:"+(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服务,访问/thttp://est/async接口,能看到任务耗时只有1s

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


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Python 树表查找_千树万树梨花开,忽如一夜春风来(二叉排序树、平衡二叉树)(python是什么意思)
下一篇:使用pytorch自定义DataSet,以加载图像数据集为例,实现一些骚操作(pytorch自己做数据集)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~