【面试必备】简单了解下ExecutorService

2,014 阅读1分钟

在Java 5之后,ExecutorService类被引入,主要是为了方便线程的统一管理。

ExecutorService的作用

ExecutorService其实是一个线程池,它可以接收任务,然后根据配置来分配线程,并控制其调度。

分类

newCacheThreadPool

  • 这种线程池是无界线程池,即它可以创建任意条线程。
  • 每次创建新线程时,先检查自己的缓存池中有没有,没有才会创建。
  • 它有默认的TimeOut(=60s),超过这个时长没活动的线程就会被自动的移除,所以完全不必要担心线程的结束问题。
  • 这是比较推荐的类型。

newFixedThreadPool

这个线程和newCacheThreadPool很类似,不同点在于:

  • 它有线程数量上限。
  • 它没有默认的TimeOut。

ScheduledThreadPool

  • 它可以按照顺序延迟调度线程。

SingleThreadPool

  • 它只有一条线程。
  • 感觉并没有多大用处。

ThreadPoolExecutor

这种类型的线程池可以自己配置相关参数。


参数说明
corePoolSize池中所保存的线程数,包括空闲线程。
maximumPoolSize池中允许的最大线程数。’
keepAliveTime当线程数大于核心时,此为终止多余的空闲等待新任务的线程的最长时间。
workQueue执行前用于保持任务的队列。此队列仅保持由 execute 方法提交的 Runnable 任务。