既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢? 请比较它们的异同。

1. SingleThreadExecutor 线程池

这个线程池只有一个核心线程在工作,也就是相当于单线程串行执行所有任务。如果这个唯一的线程因为异常结束,那么会有一个新的线程来替代它。此线程池保证所有任务的执行顺序按照任务的提交顺序执行。

  • corePoolSize:1,只有一个核心线程在工作。
  • maximumPoolSize:1。
  • keepAliveTime:0L。
  • workQueue:new LinkedBlockingQueue<Runnable>(),其缓冲队列是无界的。

2. FixedThreadPool 线程池

FixedThreadPool 是固定大小的线程池,只有核心线程。每次提交一个任务就创建一个线程,直到线程达到线程池的最大大小。线程池的大小一旦达到最大值就会保持不变,如果某个线程因为执行异常而结束,那么线程池会补充一个新线程。
FixedThreadPool 多数针对一些很稳定很固定的正规并发线程,多用于服务器。

  • corePoolSize: nThreads
  • maximumPoolSize: nThreads
  • keepAliveTime:0L
  • workQueue:new LinkedBlockingQueue<Runnable>(),其缓冲队列是无界的。

3. CachedThreadPool 线程池

CachedThreadPool 是无界线程池,如果线程池的大小超过了处理任务所需要的线程,那么就会回收部分空闲(60秒不执行任务)线程,当任务数增加时,此线程池又可以智能的添加新线程来处理任务。线程池大小完全依赖于操作系统(或者说 JVM)能够创建的最大线程大小。SynchronousQueue 是一个是缓冲区为1的阻塞队列。缓存型池子通常用于执行一些生存期很短的异步型任务,因此在一些面向连接的 daemon 型 SERVER 中用得不多。但对于生存期短的异步任务,它是 Executor 的首选。

  • corePoolSize:0
  • maximumPoolSize: Integer.MAX_VALUE
  • keepAliveTime:60L
  • workQueue:new SynchronousQueue<Runnable>(),一个是缓冲区为1的阻塞队列。

4. ScheduledThreadPool 线程池

ScheduledThreadPool:核心线程池固定,大小无限的线程池。此线程池支持定时以及周期性执行任务的需求。创建一个周期性执行任务的线程池。如果闲置,非核心线程池会在 DEFAULT_KEEPALIVEMILLIS 时间内回收。

  • corePoolSize: corePoolSize
  • maximumPoolSize: Integer.MAX_VALUE
  • keepAliveTime: DEFAULT_KEEPALIVE_MILLIS
  • workQueue:new DelayedWorkQueue()

回复

我来回复
  • 暂无回复内容

免费咨询
免费咨询
扫码关注
扫码关注
联系站长

站长Johngo!

大数据和算法重度研究者!

持续产出大数据、算法、LeetCode干货,以及业界好资源!

2022012703491714

微信来撩,免费咨询:xiaozhu_tec

分享本页
返回顶部