欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于SpringBoot使用@Async的總結(jié)

 更新時(shí)間:2021年12月28日 15:04:07   作者:young5201314  
這篇文章主要介紹了關(guān)于SpringBoot使用@Async的總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

SpringBoot使用@Async總結(jié)

注意事項(xiàng):

如下方式會(huì)使@Async失效

1. 異步方法使用static修飾

2. 異步類沒有使用@Component注解(或其他注解)導(dǎo)致spring無法掃描到異步類

3. 異步方法不能與異步方法在同一個(gè)類中

4. 類中需要使用@Autowired或@Resource等注解自動(dòng)注入,不能自己手動(dòng)new對(duì)象

5. 如果使用SpringBoot框架必須在啟動(dòng)類中增加@EnableAsync注解

6. 在Async 方法上標(biāo)注@Transactional是沒用的。 在Async 方法調(diào)用的方法上標(biāo)注@Transactional 有效。

SpringBoot實(shí)現(xiàn)異步(Async)接口

1. 啟動(dòng)類引入@EnableAsync注解

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

2. 建立異步任務(wù)類

我們建了3個(gè)異步任務(wù),分別延遲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任務(wù)耗時(shí):"+(currentTimeMillis1-currentTimeMillis)+"ms");
    }
    @Async
    public void task2() throws InterruptedException{
        long currentTimeMillis = System.currentTimeMillis();
        Thread.sleep(2000);
        long currentTimeMillis1 = System.currentTimeMillis();
        System.out.println("task2任務(wù)耗時(shí):"+(currentTimeMillis1-currentTimeMillis)+"ms");
    }
    @Async
    public void task3() throws InterruptedException{
        long currentTimeMillis = System.currentTimeMillis();
        Thread.sleep(3000);
        long currentTimeMillis1 = System.currentTimeMillis();
        System.out.println("task3任務(wù)耗時(shí):"+(currentTimeMillis1-currentTimeMillis)+"ms");
    }
}

3. 建立測(cè)試接口

@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任務(wù)總耗時(shí):"+(currentTimeMillis1-currentTimeMillis)+"ms";
    }
}

啟動(dòng)SpringBoot服務(wù),訪問/test/async接口,能看到任務(wù)耗時(shí)只有1s

在這里插入圖片描述

查看控制臺(tái),發(fā)現(xiàn)異步task也成功執(zhí)行了!

在這里插入圖片描述

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論