JAVA 基础知识

Java-线程池(一)

2019-04-14  本文已影响0人  vvweilong

最近面试线程池的问题很多,今天抽空看看源码吧。
首先我们创建线程池的时候有两种方法:
1、使用Excutors 类提供的静态方法;
2、直接new 一个ThreadPool ;
今天就先看 Excutors 的方法吧;


一共提供了8种线程池 ,分为 ThreadPool与Executor 两大类
1、FixedThreadPool 指定数量的线程池
2、SingleThreadExcutor 单线程线程池
3、CachedThreadPool 无限制数量线程池
4、ScheduledThreadPool 时间可控线程池
5、SingleThreadScheduledExecutor 单线程时间可控线程池
6、WorkStealingPool 并行线程池
7、unconfigurableScheduledExecutorService ?
9、unconfigurableExecutorService?

首先看 FixedThreadPool




有两个方法
最终的实现 都是创建了一个新的ThreadPoolExecutor对象


newFixedThreadPool
newSingleThreadExecutor
newCachedThreadPool

固定数量线程池与单线程线程池也是创建了ThreadPoolExecutor对象,并且参数几乎一样 只有线程的最大与最小值数量不相同 ,下面看一下ThreadPoolExecutor类

image.png
首先
param corePoolSize 线程池中核心线程数量
param maximumPoolSize 最大线程数量
可以看出 corePoolSize保证了线程池的最少的线程数量即使是空闲的线程也会保持它的存在,而maximumPoolSize 限定了线程池的最大线程数量,所以通过这两个参数的控制 可以分别创建出可变数量的、固定数量的、以及单线程的线程池。
而singleThreadExecutor与fixedThreadPool 和cachedThreadPool 的不同是
singleThreadExecutor创建的是一个ExecutorService对象
而另外两个创建的是一个 ThreadPoolExecutor对象
这两个对象有什么区别呢?先看下FinalizableDelegatedExecutorService的继承关系
再看ThreadPoolExecutor的继承关系
好像有点眼熟
看来二者都是AbstractExecutorService的子类
那我们来看看 究竟FinalizableDelegatedExecutorService 和ThreadPoolExecutor有什么不同
首先看第一个不同的父类
DelegatedExecutorService 类注释说 这是个装饰类,仅实现了ExecutorService接口方法。
而再看看ThreadPoolExecutor 的方法列表 要比DelegatedExecutorService多很多,
所以 DelegatedExecutorService 是个比较老实的儿子,而ThreadPoolExecutor 是个有着自己想法的儿子。
先看看父类的方法 AbstractExecutorService
主要有三类方法 newTaskFor 、 submit 、invoke newTaskFor
newTaskFor创建了一个FutureTask对象
FutureTask提供了几个对线程的操作方法

cancel 尝试取消
get 阻塞方法,获取结果,可设定阻塞时间
isCancelled 判断是否已经成功的执行了cancel方法
isdown 判断是否是线程已经完成
run 执行任务
所以可以暂时将FutureTask看成是线程的封装用来控制线程的开始结束以及获取结果操作。

submit方法


submit

方法中 调用了newTaskFor方法 也就是创建了一个FutureTask 对象,
然后执行了execute()方法 该方法有子类实现。
invoke方法 的主要实现为 doInvokeAny

然后我们回到DelegatedExecutorService 类中看看这三种方法如何使用...


DelegatedExecutorService

可以看到 方法的实现全部由ExecutorService实现而在SingleThreadExecutor创建时 这个ExecutorService 传进来的就是 ThreadPoolExecutor 尴尬不尴尬...


FinalizableDelegatedExecutorService
所以 SingleThreadExecutor 实际除了父类的方法,比FixedThreadPool多了一个finalize方法 而这个方法的实现也是 有ThreadPoolExecutor实现...
而ScheduledExecutorService
继承关系

是比ThreadPoolExecutor多实现了一个ScheduledExecutorService接口


ScheduledExecutorService接口方法
提供了一下可设定时间的方法。
下一篇 看核心类 TheadPoolExecutor 。
上一篇下一篇

猜你喜欢

热点阅读