Java-线程池(一)

最近面试线程池的问题很多,今天抽空看看源码吧。
首先我们创建线程池的时候有两种方法:
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 。
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 前段时间遇到这样一个问题,有人问微信朋友圈的上传图片的功能怎么做才能让用户的等待时间较短,比如说一下上传9张图片,...
    加油码农阅读 4,966评论 0 2
  • 线程池 程序启动一个新线程成本是比较高的,因为它涉及到要与操作系统进行交互而使用线程池可以很好的提高性能,尤其是当...
    青果果阅读 4,127评论 0 0
  • 上篇文章我们讲解了Java的四种线程池,我们知道如何去使用四种线程池,以及在合适的情况下使用合适的线程池,常言道,...
    小五666阅读 3,582评论 0 3
  • 现在奋斗的目标是娶你,给你一个温暖稳定的家。 处处洞察皆学问。读书是唯一一件能改变人生的事。
    13栋五楼扛把子阅读 1,274评论 0 0
  • 每个周五的下午我们都很高兴,因为是社团课的日子,老师交给我们做的-朵花儿,做花儿的时候我很用心、,老师也很用心的交...
    快乐生活_83dc阅读 1,711评论 0 0

友情链接更多精彩内容