jdk1.8源码探究-线程池-ThreadPoolExecutor及其周边类概述

常用的线程池都是通过ThreadPoolExecutor调节参数的实现
线程池ThreadPoolExecutor添加任务的详细流程
线程池添加任务流程
任务提交流程总结:
1.查看核心线程数是否达到最大值,如果没有到核心线程最大值,则新建worker,执行Runnable
2.核心线程数达到最大值,则将Runable往阻塞队列中去存(阻塞队列,后续会详细研究)
3.如果阻塞队列存满了,非核心线程数没有到非核心线程数最大值,则创建非核心线程
4.非核心线程到达最大值了,执行拒绝策略
ThreadPoolExecutor的构造函数

public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TimeUnit unit,
                              BlockingQueue<Runnable> workQueue,ThreadFactory threadFactory,
                              RejectedExecutionHandler handler)

结合上图详解:

  • corePoolSize:核心线程数
  • maximumPoolSize:线程池最大线程数,核心线程+非核心线程
  • keepAliveTime:非核心线程在没有任务时的存活时间
  • unit:非核心线程在没有任务时的存活时间单位
  • workQueue:阻塞队列
  • threadFactory:产生线程的工厂类
  • handler:执行的拒绝策略
阻塞队列
  • ArrayBlockingQueue:数组队列
  • LinkedBlockingDeque:链表队列
  • LinkedTransferQueue:是基于链表的FIFO无界阻塞队列,它出现在JDK7中。Doug Lea 大神说LinkedTransferQueue是一个聪明的队列。它是ConcurrentLinkedQueue、SynchronousQueue (公平模式下)、无界的LinkedBlockingQueues等的超集
  • SynchronousQueue:有多个生产者,可以并发生产产品,把产品置入队列中,如果队列满了,生产者就会阻塞;
    有多个消费者,并发从队列中获取产品,如果队列空了,消费者就会阻塞;
拒绝策略:

CallerRunsPolicy:将任务交由任务提交者的线程去执行
AbortPolicy:抛出一个拒绝异常
DiscardOldestPolicy:丢弃最老的任务
DiscardPolicy:对其当前任务

常用线程池

newSingleThreadExecutor,newFixedThreadPool,newCachedThreadPool,newScheduledThreadPool

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值