再识线程池

剧情回顾:
上节主要讲了为什么要使用线程池,线程池的类型,线程池的类结构图。
本节主讲内容如下:
1 线程池ThreadPoolExecutor参数含义
首先了解一下ThreadPoolExecutor参数组成

4377DDED-B217-4B9B-86C9-2C92D1E96F90.png

int corePoolSize, //核心线程数量
int maximumPoolSize, //最大线程数量
long keepAliveTime, //存活时间
TimeUnit unit, //指明存活时间使用的单位
BlockingQueue<Runnable> workQueue, //阻塞队列
ThreadFactory threadFactory, //产生线程的工厂类 RejectedExecutionHandler handler //拒绝策略
corePoolSize就是我们配置的线程池中可以使用线程的数量,
maximumPoolSize是最大线程的数量,当阻塞队列已满的时候会判断是否超过最大线程数量
workQueue阻塞队列,当线程池中的线程的数量超过corePoolSize的数量的时候,就会将创建的新的线程加入到阻塞队列,这个阻塞队列默认的情况下是LinkedBlockingQueue有界队列,上界为int最大值,Cachethreadpool 用的不是LinkedBlockingQueue,而是synchronousblockingqueue
ThreadFactory这个就是一个线程的产生工厂无需多讲,
主要看一下RejectedExecutionHandler,这个就是所谓的拒绝策略,为什么又会这个呢?也就是阻塞队列满了的时候需要有个拒绝的策略,默认情况下是AbortPolicy抛出异常,还有其他的几种CallerRunsPolicy,DiscardPolicy,DiscardOldestPolicy分别的含义为:
CallerRunsPolicy:这个拒绝策略的做法是会暂停当前线程池中运行的任务,直接运行当前新建的任务。
DiscardPolicy:对新建的任务什么也不做直接丢弃,不会影响现在的线程池。
DiscardOldestPolicy:会将当前线程池阻塞队列对尾任务丢弃,然后将新建的任务加入队列
线程池处理流程图:
阻塞队列是否已满.png

2 线程池ThreadPoolExecutor类的组成成分


Paste_Image.png

主要包含了一个work,每一个work其实就是一个线程,并且work还extends AbstractQueuedSynchronizer因此有了锁的功能,所谓的线程池就是一个一个的work构成的一个hashset集合,还有 ReentrantLock mainLock 主要起到加锁的作用。
基本参数和组成部分就这些了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 博客链接:http://www.ideabuffer.cn/2017/04/04/深入理解Java线程池:Thre...
    闪电是只猫阅读 16,018评论 15 133
  • 一、多线程 说明下线程的状态 java中的线程一共有 5 种状态。 NEW:这种情况指的是,通过 New 关键字创...
    Java旅行者阅读 10,186评论 0 44
  • 前段时间遇到这样一个问题,有人问微信朋友圈的上传图片的功能怎么做才能让用户的等待时间较短,比如说一下上传9张图片,...
    加油码农阅读 4,940评论 0 2
  • 成熟就是面对同一件事,以前的你会嬉笑怒骂皆表露无疑,现在的你却学会了在不同的场合扮演着那个永远波澜不惊的角色...
    诗与彼方阅读 1,514评论 0 1
  • 虽说年纪大了不喜欢过生日,但是心底里仍然希望有人能记得这天。我小时候,过生日无非是两个鸡蛋加一碗面,居然也...
    浑水摸鱼儿阅读 3,126评论 0 1