简介
Executors.newSingleThreadExecutor()这种的实现方式,看名字我们就应该知道是使用单线程重来支持的。那这个是如何实现的呢,接下来我们通过分析代码说明
请看这段代码片段
public static ExecutorService newSingleThreadExecutor() {
return new FinalizableDelegatedExecutorService
(new ThreadPoolExecutor(1, 1,
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>()));
}
public static ExecutorService newFixedThreadPool(int nThreads) {
return new ThreadPoolExecutor(nThreads, nThreads,
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>());
}
在代码的最中间部分我们可以看到,这段代码实例化了一个ThreadPoolExecutor并且容量是1,这个Executors.newFixedThreadPool(1);的效果大致上是一样的。但是有时有些区别的。
特性
jdk的注释说明有介绍 ,它和其他的实现 newFixedThreadPool(1)代码的区别在于,它不支持设置corePoolSize。保证不可使用额外的线程。
jdk注释如下
Unlike the otherwise equivalent {@code newFixedThreadPool(1)} the returned executor is guaranteed not to be reconfigurable to use additional threads.
FinalizableDelegatedExecutorService重写了finalize方法,并且在该方法中调用了super.shutdown()。它实现了在GC的时候会关闭线程。