线程池

再识线程池

2017-01-15  本文已影响26人  小鱼嘻嘻

剧情回顾:
上节主要讲了为什么要使用线程池,线程池的类型,线程池的类结构图。
本节主讲内容如下:
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 主要起到加锁的作用。
基本参数和组成部分就这些了。

上一篇 下一篇

猜你喜欢

热点阅读