@Async注解配合@EnableAsync注解使用
前言
@Async為異步注解,放到需要使用異步的方法上面,表示調(diào)用該方法的線程與此方法異步執(zhí)行,需要配合@EnableAsync注解使用。
沒(méi)有異步執(zhí)行,沒(méi)有@Async注解時(shí)
1、創(chuàng)建一個(gè)普通的類,并注入到IOC容器中
package com.example.demo;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
@Component
public class CountNumber {
? ? public void PrintNumber(){
? ? ? ? for(int i=1; i<10; i++){
? ? ? ? ? ? System.out.println("i = " + i);
? ? ? ? }
? ? }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
2、在Spring Boot的啟動(dòng)類中獲取IOC的bean
package com.example.demo;
import java.util.concurrent.TimeUnit;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.ComponentScan;
//@SpringBootApplication
@ComponentScan
public class Springboot3Application {
? ? public static void main(String[] args) throws Exception {
? ? ? ? ConfigurableApplicationContext context = SpringApplication.run(Springboot3Application.class, args);
? ? context.getBean(CountNumber.class).PrintNumber();
? ? ? ? for(int i=1; i<10; i++){
? ? ? ? ? ? System.out.println("------------------");
? ? ? ? }
? ? ? ? context.close();
? ? }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
3、運(yùn)行輸出結(jié)果
i = 1
i = 2
i = 3
i = 4
i = 5
i = 6
i = 7
i = 8
i = 9
------------------
------------------
------------------
------------------
------------------
------------------
------------------
------------------
------------------
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
從輸出結(jié)果中可以看出,啟動(dòng)類先從IOC容器中獲取CountNumber的對(duì)象,然后執(zhí)行該對(duì)象的PrintNumber方法,循環(huán)打印了9個(gè)數(shù)字,方法執(zhí)行結(jié)束后,繼續(xù)回到啟動(dòng)類中往下執(zhí)行,因此開(kāi)始執(zhí)行for循環(huán)語(yǔ)句。從整個(gè)流程看屬于順序執(zhí)行的。
異步執(zhí)行任務(wù),加入@Async注解時(shí)
1、創(chuàng)建一個(gè)普通類,并注入到IOC容器中,并在該類的方法上標(biāo)注@Async注解,表示該方法是異步執(zhí)行的
package com.example.demo;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Component;
@Component
public class CountNumber {
? ? @Async
? ? public void PrintNumber(){
? ? ? ? for(int i=1; i<10; i++){
? ? ? ? ? ? System.out.println("i = " + i);
? ? ? ? }
? ? }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
2、從spring boot啟動(dòng)類中獲取IOC中的bean,在啟動(dòng)類上標(biāo)注@EnableAsync注解,啟動(dòng)@Async異步注解。或者在啟動(dòng)類中只標(biāo)注@SpringBootApplication注解,因?yàn)樵撟⒔庵幸呀?jīng)包含了上面兩個(gè)注解。
package com.example.demo;
import java.util.concurrent.TimeUnit;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.ConfigurableApplicationContext;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.annotation.EnableAsync;
/*@SpringBootApplication注解與@ComponentScan、@EnableAsync注解達(dá)到相同的功效*/
//@SpringBootApplication
@ComponentScan
@EnableAsync
public class Springboot3Application {
? ? public static void main(String[] args) throws Exception {
? ? ? ? ConfigurableApplicationContext context = SpringApplication.run(Springboot3Application.class, args);
? ? ? ? /*@Async和@EnableAsync配合使用*/
? ? context.getBean(CountNumber.class).PrintNumber();
? ? ? ? for(int i=1; i<10; i++){
? ? ? ? ? ? TimeUnit.MICROSECONDS.sleep(1);
? ? ? ? ? ? System.out.println("------------------");
? ? ? ? }
? ? ? ? context.close();
? ? }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
3、執(zhí)行啟動(dòng)類,輸出結(jié)果如下:
------------------
------------------
------------------
------------------
------------------
------------------
i = 1
i = 2
i = 3
i = 4
i = 5
i = 6
i = 7
i = 8
i = 9
------------------
------------------
------------------
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
從輸出結(jié)果中可以看出,spring boot在獲取到IOC中的CountNumber對(duì)象后,一方面繼續(xù)向下執(zhí)行,執(zhí)行for循環(huán)語(yǔ)句,另一方面獲取對(duì)象后,執(zhí)行對(duì)象中的PrintNumber方法。因此PrintNumber方法是與主線程是異步執(zhí)行的。
————————————————
版權(quán)聲明:本文為CSDN博主「時(shí)光無(wú)聲_l」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/liuziteng0228/article/details/82825320
總結(jié)
以上是生活随笔為你收集整理的@Async注解配合@EnableAsync注解使用的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: @RequiredArgsConstru
- 下一篇: springboot activiti工