自定义线程池

来源:互联网 发布:知乎 陈寅恪 成就 编辑:程序博客网 时间:2024/06/10 00:05

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


准备工作:

  • 根据ThreadPoolExecutor 的参数 ,走一遍线程池执行的流程.
参数名 作用 corePoolSize 核心线程池大小 maximumPoolSize 最大线程池大小 keepAliveTime 线程池中超过corePoolSize数目的空闲线程最大存活时间;可以allowCoreThreadTimeOut(true)使得核心线程有效时间 TimeUnit keepAliveTime时间单位 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 如果执行程序尚未关闭,则位于工作队列头部的任务将被删除,然后重试执行程序(如果再次失败,则重复此过程)。

原创粉丝点击