一.概念
同步: 同步就是整个处理过程顺序执行,当各个过程都执行完毕之后,返回结果。
异步: 调用者无需等待被调用的方法完全执行完毕,而是继续执行下面的流程。
二.异步多线程概述
在实际项目开发中很多业务场景需要使用异步去完成,比如消息通知,日志记录以及完成大数据的导入导出等常用的功能都可以通过异步去执行,提高效率。
1.@Async的默认使用
如果在方法上直接使用注解@Async,默认使用的线程池是SimpleAsyncTaskExecutor,默认线程池会为每个任务新起一个线程,默认线程数不做限制,不复用线程,也就说只要你的任务耗时长一点,说不定服务器就给你来个OOM,最好的办法就是使用自定义的线程池。自定义线程池,可对系统中线程池更加细粒度的控制,方便调整线程池大小配置,线程执行异常控制和处理。
2.自定义线程池来使用@Async
如果想要@Async默认调用自定义的线程池,关于@Async的默认调用规则,会优先查询实现了AsyncConfigurer这个接口的类或者继承AsyncConfigurerSupport的类,所以可以按照如下代码中自定义线程池。新建一个线程池配置类,@EnableAsync在配置类上加,不用在启动类上加也行,用来开启对异步任务的支持。可以配置不同的线程池,如果配置了多个线程池,可以用@Async(“name”),那么表示线程池的@Bean的name,来指定用哪个线程池处理,假如只配置了一个线程池,直接用@Async就会用自定义的线程池执行。假如配置了多个线程池,用@Async没指定用哪个线程池,会用默认的SimpleAsyncTaskExecutor来处理。
@Configuration
//表示开启对异步任务的支持
@EnableAsync
//关于@Async的默认调用规则,会优先查询源码中实现AsyncConfigurer这个接口的类
//若想让@Async默认调用自定义线程池,则可以实现该接口
public class ExecutorConfig implements AsyncConfigurer {
//获取属性文件中对应的值,如果属性文件中没有这个属性,则获取赋予的默认值,如默认核心线程数为4
<