ThreadPoolExecutor是应用最广的底层线程池类,它实现了Executor和ExecutorService接口。
下面创建一个线程池,通过调整线程池构造函数的参数来了解线程池的运行特性。把核心线程数设置为3,最大线程数设置为8,阻塞队列的容量设置为5。
(1)当要执行的任务数小于核心线程数时,直接启动与任务数相同的工作线程。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lizYO2tW-1678433605839)(null)]
(2)当任务数量大于核心线程数时,超过核心线程数的任务会自动加入阻塞队列中,直到把阻塞队列装满。
(3)当任务数大于“最大线程数+阻塞队列容量”时,会抛出RejectedExecutionException(拒绝执行任务)异常。当前线程池的设置参数,最大容量是8+5=13,当任务数超过13时,都会被拒绝。
调用ThreadPoolExecutor的shutdown()方法或shutdownNow()方法,可以关闭线程池。
调用shutdown()方法后,原来提交的任务会被有序执行