5、@Async注解配合@EnableAsync注解使用

来源:互联网 发布:随手科技怎么样知乎 编辑:程序博客网 时间:2024/06/13 23:29

@Async为异步注解,放到方法上,表示调用该方法的线程与此方法异步执行,需要配合@EnableAsync注解使用。下面通过示例演示

一、没有@Async注解,没有异步执行时

1、创建一个普通类CountNumber,并注入到IOC容器中

package com.example.demo;import org.springframework.scheduling.annotation.Async;import org.springframework.stereotype.Component;@Componentpublic class CountNumber {    public void PrintNumber(){        for(int i=1; i<10; i++){            System.out.println("i = " + i);        }    }}

2、在spring boot的启动类中获取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@ComponentScanpublic 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();    }}

3、运行输出结果:

i = 1i = 2i = 3i = 4i = 5i = 6i = 7i = 8i = 9------------------------------------------------------------------------------------------------------------------------------------------------------------------

从输出结果中可以看出,启动类先从IOC容器中获取CountNumber的对象,然后执行该对象的PrintNumber方法,循环打印了9个数字,方法执行结束后,继续回到启动类中往下执行,因此开始执行for循环语句。从整个流程看属于顺序执行的。

二、有@Async注解,异步执行时

1、创建一个普通类CountNumber,并注入到IOC容器中,并在该类的方法上标注@Async注解,表示该方法是异步执行的。

package com.example.demo;import org.springframework.scheduling.annotation.Async;import org.springframework.stereotype.Component;@Componentpublic class CountNumber {    @Async    public void PrintNumber(){        for(int i=1; i<10; i++){            System.out.println("i = " + i);        }    }}

2、从spring boot启动类中获取IOC中的bean,在启动类上标注@EnableAsync注解,启动@Async异步注解。或者在启动类中只标注@SpringBootApplication注解,因为该注解中已经包含了上面两个注解。

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注解达到相同的功效*///@SpringBootApplication@ComponentScan@EnableAsyncpublic 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();    }}

3、执行启动类,输出结果如下:

------------------------------------------------------------------------------------------------------------i = 1i = 2i = 3i = 4i = 5i = 6i = 7i = 8i = 9------------------------------------------------------

从输出结果中可以看出,spring boot在获取到IOC中的CountNumber对象后,一方面继续向下执行,执行for循环语句,另一方面获取对象后,执行对象中的PrintNumber方法。因此PrintNumber方法是与主线程是异步执行的。

原创粉丝点击