线程池的创建分为两种方式:ThreadPoolExecutor 和 Executors,上一节学习了 ThreadPoolExecutor 的使用方式,本节重点来看 Executors 是如何创建线程池的。
Executors 可以创建以下六种线程池。
-
FixedThreadPool(n):创建一个数量固定的线程池,超出的任务会在队列中等待空闲的线程,可用于控制程序的最大并发数。
-
CachedThreadPool():短时间内处理大量工作的线程池,会根据任务数量产生对应的线程,并试图缓存线程以便重复使用,如果限制 60 秒没被使用,则会被移除缓存。
-
SingleThreadExecutor():创建一个单线程线程池。
-
ScheduledThreadPool(n):创建一个数量固定的线程池,支持执行定时性或周期性任务。
-
SingleThreadScheduledExecutor():此线程池就是单线程的 newScheduledThreadPool。
-
WorkStealingPool(n):Java 8 新增创建线程池的方法,创建时如果不设置任何参数,则以当前机器处理器个数作为线程个数,此线程池会并行处理任务,不能保证执行顺序。
下面分别来看以上六种线程池的具体代码使用。
FixedThreadPool 使用
创建固定个数的线程池,具体示例如下:
ExecutorService

本文详细介绍了Java中Executors创建的五种线程池:FixedThreadPool、CachedThreadPool、SingleThreadExecutor、ScheduledThreadPool和SingleThreadScheduledExecutor,包括它们的特点和使用场景。同时,文章讨论了ThreadPoolExecutor与Executors的区别,强调了在实际开发中不推荐使用Executors创建线程池的原因,以及可能引发的内存溢出风险。
订阅专栏 解锁全文
1175

被折叠的 条评论
为什么被折叠?



