线程池工作流程
参考源码,线程池的构造函数有7个参数:
-
corePoolSize 核心池大小:线程池核心线程大小
-
maximumPoolSize 最大池容量:线程池最大接受线程数量
-
keepAliveTime 存活时间:空闲线程存活时间
-
unit 时间单元:空闲线程存活时间单位
-
workQueue工作队列:一种阻塞队列,用来存储等待线程执行的任务
-
threadFactory 线程工厂:用来创建线程的工厂
-
handler 拒绝策略:线程池满以后,拒绝任务时采取的策略
四种workQueue工作队列
①ArrayBlockingQueue数组阻塞队列 基于数组的有界阻塞队列,按FIFO排序
②LinkedBlockingQuene链接阻塞队列
基于链表的无界阻塞队列(其实最大容量为Interger.MAX),按FIFO排序
③SynchronousQuene同步队列 一个不缓存任务的阻塞队列,生产者放入一个任务必须等到消费者取出这个任务
④PriorityBlockingQueue优先级阻塞队列 具有优先级的无界阻塞队列,优先级通过参数Comparator实现
四种handler拒绝策略
①CallerRunsPolicy在调用者线程中直接执行被拒绝任务的run方法,除非线程池已经shutdown,则直接抛弃任务
②AbortPolicy直接丢弃任务,并抛出RejectedExecutionException异常
③DiscardPolicy直接丢弃任务,什么都不做
④DiscardOldestPolicy抛弃进入队列最早的那个任务,然后尝试把这次拒绝的任务放入队列
参考https://blog.youkuaiyun.com/ye17186/article/details/89467919