在之前的项目中是使用了ThreadPoolTaskThread来实现线程池,在sping配置文件要配置里的内容确实不多,但是每使用一次都要注入bean,并且调用execute(Runnable)方法来实现,具体实现参考我的另一篇文章:ThreadPoolTaskExecutor简单实现线程池
今天要说的是使用@Async来实现线程池,简单且实用。
1.在spring.xml配置异步线程池,task:annotation-driven注解是让@Async注解生效的,配置的asyncExecutor是缺省线程池,可以配置多个,在注解的时候注明是哪个就行了,例如@Async(“logExecutor”)就是调用logExecutor这个线程池。如果直接使用@Async则会使用默认的线程池。
<task:annotation-driven executor="asyncExecutor" mode="proxy"/>
<!-- 缺省的异步任务线程池 -->
<task:executor id="asyncExecutor" pool-size="10-500" queue-capacity="60" rejection-policy="ABORT"
keep-alive="10"/>
<task:executor id="logExecutor" pool-size="10-500" queue-capacity="60" rejection-policy="ABORT"
keep-alive="10"/>
2.接下来就简单了,在需要使用多线程的方法上加上@Async注解,就会开启多线程,这里值得注意的是在本类中调用异步方法是不生效的,具体原因博主还在探究。