美文网首页
JAVA线程池(转)

JAVA线程池(转)

作者: MaTae | 来源:发表于2020-03-18 17:17 被阅读0次

    原理概述

    其实java线程池的实现原理很简单,说白了就是一个线程集合workerSet和一个阻塞队列workQueue。当用户向线程池提交一个任务(也就是线程)时,线程池会先将任务放入workQueue中。workerSet中的线程会不断的从workQueue中获取线程然后执行。当workQueue中没有任务的时候,worker就会阻塞,直到队列中有任务了就取出来继续执行。

    线程池的几个主要参数的作用

    public ThreadPoolExecutor(int corePoolSize,

                                  int maximumPoolSize,

                                  long keepAliveTime,

                                  TimeUnit unit,

                                  BlockingQueue<Runnable> workQueue,

                                  ThreadFactory threadFactory,

                                  RejectedExecutionHandler handler)

    corePoolSize: 规定线程池有几个线程(worker)在运行。

    maximumPoolSize: 当workQueue满了,不能添加任务的时候,这个参数才会生效。规定线程池最多只能有多少个线程(worker)在执行。

    keepAliveTime: 超出corePoolSize大小的那些线程的生存时间,这些线程如果长时间没有执行任务并且超过了keepAliveTime设定的时间,就会消亡。

    unit: 生存时间对于的单位

    workQueue: 存放任务的队列

    threadFactory: 创建线程的工厂

    handler: 当workQueue已经满了,并且线程池线程数已经达到maximumPoolSize,将执行拒绝策略。

    任务提交后的流程分析

    用户通过submit提交一个任务。线程池会执行如下流程:

    判断当前运行的worker数量是否超过corePoolSize,如果不超过corePoolSize。就创建一个worker直接执行该任务。—— 线程池最开始是没有worker在运行的

    如果正在运行的worker数量超过或者等于corePoolSize,那么就将该任务加入到workQueue队列中去。

    如果workQueue队列满了,也就是offer方法返回false的话,就检查当前运行的worker数量是否小于maximumPoolSize,如果小于就创建一个worker直接执行该任务。

    如果当前运行的worker数量是否大于等于maximumPoolSize,那么就执行RejectedExecutionHandler来拒绝这个任务的提交。

    ————————————————

    版权声明:本文为CSDN博主「疯狂哈丘」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。

    原文链接:https://blog.csdn.net/u013332124/article/details/79587436

    相关文章

      网友评论

          本文标题:JAVA线程池(转)

          本文链接:https://www.haomeiwen.com/subject/tpscyhtx.html