一、ThreadPoolTaskExecutor的重要参数
corePoolSize:核心线程数,线程池维护线程的最少数量。
allowCoreThreadTimeOut:是否允许核心线程超时(默认为false)。当为true是,小于等于核心线程数的线程超时会关闭;为false是,小于等于核心线程数的核心线程会一直存活,不管有没有任务。
maxPoolSize:最大线程数量。
keepAliveSeconds:允许空闲时间。如果allowCoreThreadTimeOut为true,则线程空闲时间到达keepAliveSeconds后,该线程会销毁。
queueCapacity:阻塞队列
1.当前线程池中线程数量<corePoolSize,则会新建一个线程执行任务;
2.corePoolSize=<当前线程池中线程数量<maxPoolSize,且阻塞队列还没有满,则将任务放入阻塞队列;
3.corePoolSize=<当前线程池中线程数量<maxPoolSize,且阻塞队列已满,则会新建一个线程执行任务;
4.当前线程池中线程数量>=maxPoolSize,且阻塞队列已满,并且没有空闲的线程执行任务时,有新任务时则会执行拒绝策略;
二、拒绝策略
1.CallerRunsPolicy
如果线程池、队列都满了,添加线程池失败,则主线程会自己去执行任务,不会等待线程池中的线程去执行。
2.AbortPolicy(默认策略)
如果线程池、队列都满了,则丢弃任务,并抛出异常。
3.Disca