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

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

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(由提交任务的线程来执行该任务)。
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值