摘要:异步程序在顺序执行时,不等待异步调用的语句返回结果就执行后面的程序当一个异步过程调用发出后,调用者不能立刻得到结果。
同步
程序按照定义顺序依次执行,每一行程序都必须等待上一行程序执行完成之后才能执行,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。
异步程序在顺序执行时,不等待异步调用的语句返回结果就执行后面的程序,当一个异步过程调用发出后,调用者不能立刻得到结果。
同步代码Service层:
public void test() throws InterruptedException { Thread.sleep(2000); for (int i = 0; i < 1000; i++) { System.out.println("i = " + i); } }
Controller层:
@GetMapping("test") public String test() { try { Thread.sleep(1000); System.out.println("主线程开始"); for (int j = 0; j < 100; j++) { System.out.println("j = " + j); } asyncService.test(); System.out.println("主线程结束"); return "async"; } catch (InterruptedException e) { e.printStackTrace(); return "fail"; } }
浏览器中请求 http://localhost:8080/test
控制台打印顺序:
主线程开始
打印j循环
打印i循环
主线程结束
异步代码在Service层的test方法上加上@Async注解,同时为了是异步生效在启动类上加上@EnableAsync注解
Service层:
@Async public void test() throws InterruptedException { Thread.sleep(2000); for (int i = 0; i < 1000; i++) { System.out.println("i = " + i); } }
Controller不变,启动类加上@EnableAsync:
@SpringBootApplication @EnableAsync public class AsyncApplication { public static void main(String[] args) { SpringApplication.run(AsyncApplication.class, args); } }
再次请求打印顺序如下:
主线程开始
打印j循环
主线程结束
打印i循环
代码: async
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/77551.html
摘要:异步处理方式调用之后,不返回任何数据。在有返回值的异步调用中,异步处理抛出异常,会直接抛出异常,异步任务结束,原有处理结束执行。 1.使用背景 在项目中,当访问其他人的接口较慢或者做耗时任务时,不想程序一直卡在耗时任务上,想程序能够并行执行,我们可以使用多线程来并行的处理任务,也可以使用spring提供的异步处理方式@Async。 2.异步处理方式 调用之后,不返回任何数据。 调用之...
摘要:定义异步方法,使用来返回异步调用的结果开始做任务一完成任务一,当前线程,耗时毫秒任务一完成开始做任务二完成任务二,当前线程,耗时毫秒任务二完成开始做任务三完成任务三,当前线程,耗时毫秒任务三完成调用执行异步回调异步回调结束调用结果开 定义异步方法,使用Future来返回异步调用的结果 @Async public Future firstTask() throws Int...
摘要:定义模拟耗时操作调用失败调用成功调用执行顺序循环循环调用成功代码异步回调 定义ListenableFuture public void getListenableFuture() { ListenableFutureTask task = new ListenableFutureTask(new Callable() { @Override ...
摘要:最开始是使用的正常的普通方式去写入,但是量太大了,所以就尝试使用多线程来写入。下面我们就来介绍一下怎么使用多线程进行导入。配置线程池我们需要创建一个类来设置线程池的各种配置。它可以使主线程一直等到所有的子线程执行完之后再执行。 前言: 最近在工作中需要将一大批数据导入到数据库中,因为种种原因这些数据不能使用同步数据的方式来进行复制,而是提供了一批文本,文本里面有很多行url地址,需要的...
阅读 3149·2021-11-25 09:43
阅读 3188·2021-11-23 09:51
阅读 3500·2019-08-30 13:08
阅读 1506·2019-08-29 12:48
阅读 3575·2019-08-29 12:26
阅读 378·2019-08-28 18:16
阅读 2543·2019-08-26 13:45
阅读 2396·2019-08-26 12:15