当前位置:   article > 正文

java线程池详解(01)_java 线程池是什么数据结构

java 线程池是什么数据结构

什么是线程池?

        线程池:顾名思义就是事先创建若干个可执行的线程放入一个池(容器)中,需要的时候从池中获取线程不用自行创建,使用完毕不需要销毁线程,而是返回池中从而减少创建和销毁对象对CPU和内存的开销.

       例如:线程池的概念类似人才资源中心,原本每次要运行一个线程(公司找一个员工)都必须去创建(培养)一个员工才行,有了线程池之后就在线程池中准备了多个创建好的线程(培训好的员工)等待被调用 

线程池的主要作用?

    1、不同请求之间重复利用线程,无需频繁的创建和销毁线程,降低系统开销;

    2、控制线程数量上限,避免创建过多的线程耗尽进程内存空间,

    3、能更好的控制线程的开启与回收,并且能定时执行任务。

线程池的核心原理?

     1、 线程池由两个核心数据结构组成:

      1)线程集合(workers):存放执行任务的线程,是一个HashSet;

      2)任务等待队列(workQueue):存放等待线程池调度执行的任务,是一个阻塞式队列BlockingQueue;

2、任务由execute方法提交到线程池中调度,在提交任务时会有下面几种场景:

     1)线程池中线程数量小于corePoolSize,此时任务不会进等待队列,线程池直接创建一个线程Worker执行提交的任务;

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号