`
ncs123
  • 浏览: 103500 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

ThreadPoolExecutor源码解析

    博客分类:
  • java
阅读更多
一、ThreadPoolExecutor简介

  使用线程池主要为了解决一下几个问题:
  • 通过重用线程池中的线程,来减少每个线程创建和销毁的性能开销。
  • 对线程进行一些维护和管理,比如定时开始,周期执行,并发数控制等等。


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

  ThreadPoolExecutor参数
  • corePoolSize:核心线程数,默认情况下核心线程会一直存活,即使处于闲置状态也不会受存keepAliveTime限制。除非将allowCoreThreadTimeOut设置为true。
  • maximumPoolSize:线程池所能容纳的最大线程数。
  • keepAliveTime:非核心线程的闲置超时时间,超过这个时间就会被回收。
  • unit:指定keepAliveTime的单位,如TimeUnit.SECONDS。
  • workQueue:线程池中的任务队列.常用的有三种队列,SynchronousQueue,LinkedBlockingDeque,ArrayBlockingQueue。
  • threadFactory:线程工厂,提供创建新线程的功能。默认:DefaultThreadFactory
  • handler:当任务队列满并且线程数达到maximumPoolSize时,会调用RejectedExecutionHandler.rejectedExecution()方法,默认:AbortPolicy


  JDK自带的RejectedExecutionHandler
  • DiscardOldestPolicy:会丢弃workQueue中最老的任务,这个Runnable放入workQueue。
  • AbortPolicy:直接throw RejectedExecutionException。
  • CallerRunsPolicy:在主线程执行这个Runnable。
  • DiscardPolicy:不处理,丢弃这个Runnalbe。
  • NewThreadRunsPolicy:新起线程执行Runnable。


二、ThreadPoolExecutor源码
        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(1,10,10, TimeUnit.SECONDS, new LinkedBlockingQueue<Runnable>());
        Runnable runnable = new Runnable() {
            @Override
            public void run() {
                System.out.println("aa");
            }
        };
        threadPoolExecutor.submit(runnable);



  1. 如果当前工作线程数<corePoolSize,新增一个Worker,Worker直接执行当前Runnable。
  2. 如果线程池是运行状态,并且workQueue未满,Runnable入队列。二次校验线程池是运行状态和Worker数,如果线程池已暂停,则Runnable出队列,RejectedExecutionHandler处理。如果Worker==0,新增Worker。
  3. 如果workQueue已满并且线程池Worker数<maximumPoolSize,新增Worker,并立即执行Runnable。如果线程池Worker数>=maximumPoolSize,则拒绝消息,RejectedExecutionHandler处理。



  • 新建一个Worker对象,Worker implements Runnable,并且start这个Worker。



  • 线程Worker.runWorker方法会调用getTask()去workQueue取task,如果getTask()返回无task,线程Worker执行完成,线程关闭。




  1. 如果allowCoreThreadTimeOut=true或者workerCount>corePoolSize,则time=true。
  2. 如果time=true,表示workerCount>corePoolSize,则workQueue.poll(keepAliveTime, TimeUnit.NANOSECONDS)会在keepAliveTime时间后返回,如果取不到task,Worker线程关闭。如果time=false,workQueue.take()会block线程,直到有新的task进入workQueue。

  • 大小: 97.6 KB
  • 大小: 74.1 KB
  • 大小: 77.7 KB
  • 大小: 83.9 KB
分享到:
评论

相关推荐

    ThreadPoolExecutor源码解析.md

    ThreadPoolExecutor源码解析.md

    ThreadPoolExecutor源码解析.pdf

    《ThreadPoolExecutor源码解析》 ThreadPoolExecutor是Java并发编程中重要的组件,它是ExecutorService接口的实现,用于管理和调度线程的执行。理解其源码有助于我们更好地控制并发环境下的任务执行,提高系统的...

    线程池原理-ThreadPoolExecutor源码解析

    线程池原理-ThreadPoolExecutor源码解析 1.构造方法及参数 2.阻塞对列: BlockingQueue 3.线程工厂: DefaultThreadFactory 4.拒绝策略: RejectedExecutionHandler 5.执行线程 Executor

    JDK之ThreadPoolExecutor源码分析1

    《JDK之ThreadPoolExecutor源码分析1》 在Java编程中,线程池是一种高效的管理线程的方式,它通过复用已存在的线程来避免频繁创建和销毁线程带来的开销。ThreadPoolExecutor作为Java中的线程池实现,其内部机制相当...

    Android AsyncTask 源码解析

    **Android AsyncTask 源码解析** AsyncTask 是 Android 平台上一个非常重要的工具类,用于在后台线程执行耗时操作,然后在 UI 线程更新结果,从而避免了因长时间运行任务而导致的 ANR(Application Not Responding...

    线程池ThreadPoolExecutor底层原理源码分析

    线程池ThreadPoolExecutor底层原理源码分析

    线程池ThreadPoolExecutor原理源码分析.md

    ### 线程池 `ThreadPoolExecutor` 原理源码分析 #### 一、概述 线程池作为 Java 并发编程中的重要组件,在实际应用中被广泛使用。其核心类 `ThreadPoolExecutor` 实现了对线程的管理、调度等功能。本文将围绕 `...

    源码解析文件ScheduledThreadPoolExecutor

    源码解析文件ScheduledThreadPoolExecutor 在 Java 中,ScheduledThreadPoolExecutor 是一个线程池执行器,用于执行延迟任务。它使用DelayedWorkQueue来实现延迟的效果。下面是 ScheduledThreadPoolExecutor 的实现...

    12-线程池ThreadPoolExecutor底层原理源码分析(下)-周瑜.pdf

    ### 四、线程池线程运行执行任务源码解析 线程池中每个worker线程执行任务的过程主要包括以下几个方面: 1. 获取任务:从任务队列中获取待执行的任务。 2. 执行任务:调用任务的`run`方法执行任务。 3. 任务完成:...

    《Java并发编程高阶技术-高性能并发框架源码解析与实战》学习.zip

    《Java并发编程高阶技术-高性能并发框架源码解析与实战》是一本深入探讨Java并发编程的书籍,旨在帮助读者掌握高性能并发框架的核心原理,并通过源码解析与实战演练提升技术水平。在Java的世界里,并发编程是提升...

    线程池源码解析-多线程

    本文将深入解析线程池的源码,特别关注其中的`AtomicInteger`类以及线程池状态的表示。 `AtomicInteger`是Java并发包`java.util.concurrent.atomic`中的一个原子类型类,它提供了在多线程环境下安全地修改整型变量...

    美团动态线程池实践思路开源项目(DynamicTp),线程池源码解析及通知告警篇.doc

    美团动态线程池实践思路开源项目(DynamicTp)线程池源码解析及通知告警篇 本文详细介绍了美团动态线程池实践思路开源项目(DynamicTp)的通知告警模块,该模块提供了多种通知告警功能,每一个通知项都可以独立配置...

    高并发之——通过源码深度解析ThreadPoolExecutor类是如何保证线程池正确运行的

    对于线程池的核心类ThreadPoolExecutor来说,有哪些重要的属性和内部类为线程池的正确运行提供重要的保障呢? ThreadPoolExecutor类中的重要属性 在ThreadPoolExecutor类中,存在几个非常重要的属性和方法,接下来,...

    zxing.java源码解析-StudyRoad:Java&Android开发知识点备忘

    zxing.java源码解析 StudyRoad Java & Android 知识点备忘 Java SE Thinking in Java [Java I/O](/Thinking-in-Java/Java IO.md) Android Android组件 Drawable 自定义Drawable View View工作过程 View事件分发机制 ...

    JDK1.5线程池源码及详细注释

    在Java并发编程中,线程池(ThreadPoolExecutor)是一个至关重要的工具,它允许开发者有效地管理线程资源,提高系统的性能和响应性。JDK 1.5引入了java.util.concurrent包,其中包含了线程池的实现,使得并发编程...

    Java线程池,正式上线运行的源码,分享欢迎使用并提意见

    本文将深入探讨Java线程池的原理、使用方式以及其源码解析。 首先,Java线程池主要由`java.util.concurrent.ThreadPoolExecutor`类实现。线程池的核心参数包括核心线程数(corePoolSize)、最大线程数...

    基于java开发的NIO+多线程实现聊天室+源码+项目解析(毕业设计&课程设计&项目开发)

    基于java开发的NIO+多线程实现聊天室+源码+项目解析,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用~ 项目简介: 涉及到的技术点 线程池ThreadPoolExecutor 阻塞...

    线程池管理源码 java 源码

    本文将深入解析线程池的管理源码,帮助读者理解其工作原理和优化策略。 在Java中,`java.util.concurrent`包下的`ThreadPoolExecutor`类是线程池的核心实现。它提供了丰富的参数来定制线程池的行为,包括核心线程数...

    葛一鸣 实战java高并发程序设计 源码

    《葛一鸣实战Java高并发程序设计》源码解析 在Java编程领域,高并发程序设计是一项关键且复杂的技能,涉及到多线程、同步机制、并发控制、性能优化等多个方面。该资源“葛一鸣实战Java高并发程序设计”提供了一套...

    java源码笔记

    5. **Java源码解析** - 核心库分析:深入JDK源码,如Collections、Stream、反射等模块,了解其内部实现机制。 - 设计模式:学习Java源码中常见的设计模式,如单例、工厂、观察者等,提升代码质量。 - 内存模型:...

Global site tag (gtag.js) - Google Analytics