在 一般的中小项目 使用 最多的是 quartz 定时任务,执行。就算没有线程池 也是可以 执行的。 但是 目前项目 中配置了 spring 线程池 。 而且 ThreadPoolTaskExecutor 线程池 也是可以 单独使用的。
如果 项目里面 一旦都配置了 线程池 和 quartz 的时候,就 晕了。有点蒙。。 上网百度了 一下 。 如果有了 线程池 ,那么 quartz 执行任务的时候, 取的线程 就是 线程 池里面定义的 线程的。 而且 线程池是有 一些地方是 很有帮助的,可以很好的 并发。而不让 任务或者是 程序 阻塞。 比如 2个 定时任务 A, B , 一个定时任务 A 执行的时间要得比较久, 但是 在 A 执行的时候 , 就要执行B 任务。 如果有线程池的话。 B就不会 阻塞 执行了。而且 对B 没有什么影响的。
如果是 单独 使用线程池的时候 , 比如 远程连接,需要 花费的时候比较长的时候 。就可以使用线程池 来 执行了。而不影响其他的 程序执行。 这就是 他们说的 并发。。
ThreadPoolTaskExecutor 配置
<bean id ="taskExecutor"
class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor" >
<property name ="corePoolSize" value ="5" />
<property name ="keepAliveSeconds" value ="300" />
<property name ="maxPoolSize" value ="10" />
<property name ="queueCapacity" value ="25" />
</bean>
属性字段说明:
corePoolSize: 线程池维护线程的最少数量
keepAliveSeconds 线程池维护线程所允许的空闲时间
maxPoolSize 线程池维护线程的最大数量
queueCapacity 线程池所使用的缓冲队列
使用 :
ApplicationContext ctx = new
ClassPathXmlApplicationContext("applicationContext.xml");
ThreadPoolTaskExecutor poolTaskExecutor = (ThreadPoolTaskExecutor)
ctx.getBean("taskExecutor");
Thread udpThread = new Thread(udp);
poolTaskExecutor.execute(udpThread);
获取当前线程池活动的线程数:
int count = poolTaskExecutor.getActiveCount();
logger.debug("[x] - now threadpool active threads totalNum : " +count);
参考地址: https://my.oschina.net/52love/blog/713496 以及参考 地址: https://my.oschina.net/jgy/blog/472845
参考地址: http://blog.csdn.net/pzw_0612/article/details/48211417
如果需要有 返回值 : 地址: http://blog.csdn.net/lipc_/article/details/52786377
当然 ,也要看 情况了, 如果 远程连接 反应 比较快, 那么也是不需要 使用调用,线程池的。 具体看 情况了。