总结下java线程池的处理策略

线程池

任务提交给线程池之后的处理策略:

  • 如果当前线程池中的线程数目<corePoolSize,则每来一个任务,就会创建一个线程去执行这个任务
  • 如果当前线程池中的线程数目>=corePoolSize,则每来一个任务,会尝试将其添加到任务缓存队列当中,若添加成功,则该任务会等待空闲线程将其取出去执行;若添加失败(一般来说是任务缓存队列已满),如果线程数目<maximumPoolSize则会尝试创建新的线程去执行这个任务,如果线程数目>=maximumPoolSize,则会采取任务拒绝策略进行处理

线程池中线程终止策略:

  • 如果线程池中的线程数量大于 corePoolSize时,如果某线程空闲时间(getTask)超过keepAliveTime,线程将被终止,直至线程池中的线程数目不大于corePoolSize;如果允许为核心池中的线程设置存活时间,那么核心池中的线程空闲时间(getTask)超过keepAliveTime,线程也会被终止。

猜你喜欢

转载自blog.csdn.net/huang007guo/article/details/83623867