Springboot @Async 异步请求详解

首先,大家多多少少会看到同步和异步这两个词,那么到底该如何理解呢????

1、什么是同步?

在这里插入图片描述
同步请求中,客户端发送一个请求,到达处理web服务器,然后等待web服务器返回响应结果给前端,在这个等待返回结果的过程中,客户端不可以做其他事情。

2、什么是异步?

在这里插入图片描述
异步就是当客户端发送给服务端请求时,在等待服务端响应的时候,客户端可以做其他的事情,这样节约了时间,提高了效率。

Springboot 提供了这样的一个注解@Async,处理异步请求。

3、通过一个例子了解同步异步

在启动类中添加@EnableAsync,表示开启异步线程

@EnableAsync
@SpringBootApplication
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }

}

controller方法

 @GetMapping(value = "asyn")
    public void asyn(){
        System.out.println("主线程-----------1");
        userService.asyn();
        System.out.println("主线程-----------2");
    }

sevice 逻辑处理方法


    @Override
    public void asyn() {
        System.out.println("子线程------------1");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("子线程------------2");
    }

同步运行结果如下,可以看到执行顺序是从上到下。

2019-12-01 12:41:45.823  INFO 3872 --- [nio-5689-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2019-12-01 12:41:45.824  INFO 3872 --- [nio-5689-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2019-12-01 12:41:45.836  INFO 3872 --- [nio-5689-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 12 ms
主线程-----------1
子线程------------1
子线程------------2
主线程-----------2

在逻辑处理方法上面添加@Async,@EnableAsync注解使用来开启异步线程的,使@Async起作用。

    @Async
    @Override
    public void asyn() {
        System.out.println("子线程------------1");
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("子线程------------2");
    }

异步结果如下,分析出@Async 注解的方法就相当于一个子线程,当主线程执行完,才进行子线程的执行。所以对于一些要要拿到数据才要进行的操作,只能用同步。

2019-12-01 12:45:57.372  INFO 9024 --- [nio-5689-exec-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring DispatcherServlet 'dispatcherServlet'
2019-12-01 12:45:57.372  INFO 9024 --- [nio-5689-exec-1] o.s.web.servlet.DispatcherServlet        : Initializing Servlet 'dispatcherServlet'
2019-12-01 12:45:57.382  INFO 9024 --- [nio-5689-exec-1] o.s.web.servlet.DispatcherServlet        : Completed initialization in 10 ms
主线程-----------1
主线程-----------2
子线程------------1
子线程------------2

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值