java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java 线程池参数

Java多线程中线程池常见7个参数的详解以及执行流程

作者:健康平安的活着

本文主要介绍了Java多线程中线程池常见7个参数的详解以及执行流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一 线程池常见参数

1.1 概念

1.2 7个参数说明 

7个参数:

int corePoolSize, 常驻线程数量(核心)
int maximumPoolSize,最大线程数量
long keepAliveTime,TimeUnit unit,线程存活时间
BlockingQueue<Runnable> workQueue,阻塞队列(排队的线程放入)
ThreadFactory threadFactory,线程工厂,用于创建线程
RejectedExecutionHandler handler拒绝策略(线程满了)

1.3 coresize和maxsize,poolsize

1.corePoolSize

线程池的核心线程数量,线程池的基本大小,即在没有任务需要执行的时候线程池的大小并且只有在工作队列满了的情况下才会创建超出这个数量的线程

2.maximumPoolSize

线程池中允许的最大线程数

3.poolSize

线程池中当前线程的数量

3者之间的关系:

新提交一个任务时的处理流程很明显:

1、如果当前线程池的线程数还没有达到核心线程数(poolSize < corePoolSize),无论是否有空闲的线程,都新增一个线程处理新提交的任务;

2、如果当前线程池的线程数大于或等于核心线程数(poolSize >= corePoolSize) 且任务队列未满时,就将新提交的任务提交到阻塞队列排队,等候处理workQueue.offer(command);

3、如果当前线程池的线程数大于或等于核心线程数(poolSize >= corePoolSize) 且任务队列满时

3.1、当前poolSize<maximumPoolSize,那么就新增线程来处理任务;

3.2、当前poolSize>=maximumPoolSize,那么意味着线程池的处理能力已经达到了极限,此时需要拒绝新增加的任务。至于如何拒绝处理新增的任务,取决于线程池的饱和策略RejectedExecutionHandler。

1.4 newFixedThreadPool

newFixedThreadPool中设定的线程数是核心线程数,还是最大线程数,开源代码如下:

 底层继续查看 new  ThreadPoolExecutor的源代码

通过查看源码:答案是:核心线程数和最大线程数都设置成了定义的线程数量。

到此这篇关于Java多线程中线程池常见7个参数的详解以及执行流程的文章就介绍到这了,更多相关Java 线程池参数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文