亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

SpringBoot使用@Async總結(jié)

注意事項(xiàng):

如下方式會使@Async失效

1. 異步方法使用static修飾

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

3. 異步方法不能與異步方法在同一個類中

4. 類中需要使用@Autowired或@Resource等注解自動注入,不能自己手動new對象

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

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

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

1. 啟動類引入@EnableAsync注解

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

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

我們建了3個異步任務(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ù)耗時:"+(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ù)耗時:"+(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ù)耗時:"+(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任務(wù)總耗時:"+(currentTimeMillis1-currentTimeMillis)+"ms";
    }
}

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

在這里插入圖片描述

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

在這里插入圖片描述

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

相關(guān)文章

最新評論