自定义线程池

本文转载自:
线程池参数详解
线程池源码详解


准备工作:

  • 根据ThreadPoolExecutor 的参数 ,走一遍线程池执行的流程.
参数名作用
corePoolSize核心线程池大小
maximumPoolSize最大线程池大小
keepAliveTime线程池中超过corePoolSize数目的空闲线程最大存活时间;可以allowCoreThreadTimeOut(true)使得核心线程有效时间
TimeUnitkeepAliveTime时间单位
workQueue阻塞任务队列
threadFactory新建线程工厂
RejectedExecutionHandler当提交任务数超过maxmumPoolSize+workQueue之和时,任务会交给RejectedExecutionHandler来处理
  • execute()执行流程图

执行流程

  • execute()执行流程:
    1.当线程池小于corePoolSize时,新提交任务将创建一个新线程执行任务,即使此时线程池中存在空闲线程。
    2.当线程池达到corePoolSize时,新提交任务将被放入workQueue中,等待线程池中任务调度执行
    3.当workQueue已满,且maximumPoolSize>corePoolSize时,新提交任务会创建新线程执行任务
    4.当提交任务数超过maximumPoolSize时,新提交任务由RejectedExecutionHandler处理
  • 补充:
    1.当线程池线程总数中超过corePoolSize大小,线程池会在空闲时间达到keepAliveTime时,关闭空闲线程
    2.java 1.6 加入了allowCoreThreadTimeOut(true),允许线程数低于corePoolSize时,线程也因为空闲而终止

自定义线程池:

  • 一般来讲,自定义ThreadPoolExecutor的参数就基本可以满足我们的需求.
  • 自定义线程池的目的一般两种
    自定义线程工厂Debug打印Log日志 ,自定义 RejectedExecutionHandler (线程超出maxmumPoolSize+workQueue 时的处理策略)

new ThreadPoolExecutor(1, 1,
                0L, TimeUnit.MILLISECONDS,
                new DebugThreadFactory(),
                new ThreadPoolExecutor.DiscardPolicy()
        );

RejectedExecutionHandler 的四种预定义策略:
(1) 默认的ThreadPoolExecutor.AbortPolicy 处理程序遭到拒绝将抛出运行时RejectedExecutionException;
(2) ThreadPoolExecutor.CallerRunsPolicy 线程调用运行该任务的 execute 本身。此策略提供简单的反馈控制机制,能够减缓新任务的提交速度
(3) ThreadPoolExecutor.DiscardPolicy 不能执行的任务将被删除;
(4) ThreadPoolExecutor.DiscardOldestPolicy 如果执行程序尚未关闭,则位于工作队列头部的任务将被删除,然后重试执行程序(如果再次失败,则重复此过程)。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值