一个线程进入线程池后的工作流程

一个线程进入线程池后的工作流程是一个复杂但有序的过程,它涉及到任务的提交、线程的分配、任务的执行以及线程的回收等多个环节。以下是一个详细的工作流程说明:

1. 提交任务

  • 当有任务需要执行时,这些任务(通常实现为RunnableCallable接口的实现类)会被提交到线程池中。
  • 提交任务的方法可以是ExecutorService接口中的execute(Runnable command)submit(Callable<T> task)等方法。

2. 判断并分配线程

  • 检查空闲线程:线程池会首先检查是否有空闲的线程可以立即执行任务。如果有,就分配一个空闲线程来执行新提交的任务。
  • 核心线程数判断:如果没有空闲线程,线程池会检查当前已创建的线程数是否小于核心线程数(corePoolSize)。如果是,就创建一个新的核心线程来执行任务。
  • 工作队列:如果当前线程数已经达到核心线程数,线程池会将新任务放入工作队列(如BlockingQueue)中等待执行。工作队列是一个用于存放待执行任务的阻塞队列,它的大小可以通过构造函数来指定。
  • 非核心线程数判断:如果工作队列已满,线程池会检查当前线程数是否小于最大线程数(maximumPoolSize)。如果是,就创建一个新的非核心线程来执行任务。

3. 执行任务

  • 一旦线程被分配了任务,它就会开始执行这个任务。执行过程中,线程会调用任务的run()方法(对于Runnable任务)或call()方法(对于Callable任务),并处理任务的执行结果。

4. 线程回收与复用

  • 线程复用:线程池中的线程在执行完一个任务后,并不会立即销毁。它们会在线程池中存活一段时间,等待新的任务被提交。如果在这段时间内有新的任务被提交,线程就可以被复用,执行新的任务。
  • 线程销毁:如果线程池中的线程数量超过了核心线程数,并且这些线程在一段时间内都没有被复用(即它们都处于空闲状态),那么线程池可能会销毁这些多余的线程,以节省系统资源。

5. 拒绝策略

  • 如果线程池中的线程数已经达到了最大线程数,并且工作队列也已经满了,此时再有新的任务提交到线程池,就会触发拒绝策略。拒绝策略是线程池处理无法被执行的任务的一种方式,Java提供了几种预定义的拒绝策略,如AbortPolicy(默认策略,直接抛出异常)、DiscardPolicy(丢弃任务但不抛出异常)、DiscardOldestPolicy(丢弃队列中最老的任务,然后尝试提交新任务)和CallerRunsPolicy(由提交任务的线程来执行该任务)。

相关推荐

  1. 一个线进入线工作流程

    2024-07-20 19:52:02       16 阅读
  2. 线执行流程

    2024-07-20 19:52:02       54 阅读
  3. 手写一个线

    2024-07-20 19:52:02       37 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-20 19:52:02       52 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-20 19:52:02       54 阅读
  3. 在Django里面运行非项目文件

    2024-07-20 19:52:02       45 阅读
  4. Python语言-面向对象

    2024-07-20 19:52:02       55 阅读

热门阅读

  1. Redis 内部的字符串和字典

    2024-07-20 19:52:02       20 阅读
  2. cordova使用vue进行开发

    2024-07-20 19:52:02       20 阅读
  3. 千字长文讲解python闭包

    2024-07-20 19:52:02       16 阅读
  4. 网友提问:display:flex和display:box有什么区别?

    2024-07-20 19:52:02       16 阅读
  5. 每天一个数据分析题(四百三十八)- A/Btest

    2024-07-20 19:52:02       17 阅读
  6. 为了Python换源,我开发了一个库「pipco 0.0.19」

    2024-07-20 19:52:02       20 阅读
  7. Python3 第十九课 -- 迭代器与生成器

    2024-07-20 19:52:02       22 阅读
  8. SQL

    SQL

    2024-07-20 19:52:02      15 阅读
  9. python环境搭建步骤记录

    2024-07-20 19:52:02       17 阅读
  10. 【Linux常用命令】之sed命令

    2024-07-20 19:52:02       18 阅读
  11. 简单工厂模式、工厂模式和抽象工厂模式的区别

    2024-07-20 19:52:02       15 阅读