线程池其实和连接池类似,连接池是为了不让每次访问数据库都去连接数据库,而线程池是为了不让每次需要线程的时候都去创建线程,因为创建线程也是要花费时间和空间的。因此创建一个线程池来保存一定数量的线程。
这里涉及到几个概念:
(1)corePoolSize :这个是指线程池的核心池的大小,简单的讲就是指的线程池中可以同时运行的线程池的最大线程数。线程池在创建的时候默认是没有线程的,当有任务来的时候才会去创建线程去执行任务。
(2)maximumPoolSize :线程池中允许的最大线程数,这个数是大于或等于corePoolSize的。
(3)keepAliveTime:表示线程在没有任务时最多保持多久就会停止,我的理解是线程池中同时运行的线程,突然有一个线程过了keepAliveTime时长没有运行,就会停止,将线程空闲出来让给其他的任务去执行。不过这个的前提是线程池中的线程数大于coolPoolSize,即有其他的线程等待执行,这个时候这个keepAliveTime才会起作用。
(4)Unit:keepAliveTime的单位
(5)workQuere:阻塞队列,当请求执行任务数大于coolPoolSize的时候,就会将线程放入阻塞队列等待执行。
(6)threadFactory:线程工厂,用于创建线程
(7)handler:表示当拒绝处理任务的时候的策略
其他的一些策略和创建线程池的参考链接:
https://www.cnblogs.com/superfj/p/7544971.html