Skip to content

ThreadPoolExecutor 的构造方法都有哪些参数,分别代表什么意思?

cxuan edited this page Sep 20, 2020 · 2 revisions

(1) corePoolSize 线程池中常驻核心线程数。 在创建了线程池后,当有请求任务来之后,就会安排池中的线程去执行请求任务。当线程池的线程数达到corePoolSize后,就会把到达的任务放到缓存队列当中。

(2) maximumPoolSize 线程池能够容纳同时执行的最大线程数,必须大于等于1。

(3) keepAliveTime 多余的空闲线程的存活时间。 当前线程池数量超过corePoolSize时,当空闲时间达到keepAliveTime值时,多余空闲线程会被销毁到只剩下corePoolSize个线程为止。

(4) allowCoreThreadTimeOut 是否允许核心线程的空闲线程超时。默认是false。可通过allowCoreThreadTimeOut(value)方法设置。 如果allowCoreThreadTimeOut设置为true,核心线程空闲时间达到keepAliveTime值时也会被销毁。

(5) unit keepAliveTime的单位。

(6) workQueue 任务队列,被提交但尚未被执行的任务。

(7) threadFactory 表示生成线程池中工作线程的线程工厂,用于创建线程一般用默认的即可。

(8) handler 拒绝策略,表示当队列满了并且工作线程大于等于线程池的最大线程数(maximumPoolSize)时如何来拒绝新任务执行的runable的策略。

拒绝策略: (1) AbortPolicy(默认) 直接抛出RejectedExecutionException异常阻止系统正常运行.

(2) CallerRunsPolicy 当触发拒绝策略,只要线程池没有关闭的话,则使用调用线程池对象的线程直接运行任务。一般并发比较小,性能要求不高,不允许失败。但是,由于调用者自己运行任务,如果任务提交速度过快,可能导致程序阻塞,性能效率上必然的损失较大。

(3) DiscardOldestPolicy 抛弃队列中等待最久的任务,然后把当前任务加入队列中尝试再次提交当前任务。

(4) DiscardPolicy 直接丢弃任务,不予任何处理也不抛异常。如果允许任务丢失,这是最好的一种方案。 如果需要自定义线程池拒绝任务策略,需要实现RejectedExecutionHandler接口。

Clone this wiki locally