线程池

Posted yanghaitao_1990

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了线程池相关的知识,希望对你有一定的参考价值。

什么是线程池?如果让你设计一个动态大小的线程池,如何设计,应该有哪些方法?
什么是线程池

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

设计一个动态大小的线程池,如何设计,应该有哪些方法
一个线程池包括以下四个基本组成部分:

  • 线程管理器(ThreadPool):用于创建并管理线程池,包括创建线程,销毁线程池,添加新任务;
  • 工作线程(PoolWorker):线程池中线程,在没有任务时处于等待状态,可以循环的执行任务;

  • 任务接口(Task):每个任务必须实现的接口,以供工作线程调度任务的执行,它主要规定了任务的入口,任务执行完后的收尾工作,任务的执行状态等;

  • 任务队列(TaskQueue):用于存放没有处理的任务。提供一种缓冲机制;

所包含的方法

  • private ThreadPool() 创建线程池

  • public static ThreadPool getThreadPool() 获得一个默认线程个数的线程池

  • public void execute(Runnable task)
    执行任务,其实只是把任务加入任务队列,什么时候执行有线程池管理器决定

  • public void execute(Runnable[] task)
    批量执行任务,其实只是把任务加入任务队列,什么时候执行有线程池管理器决定

  • public void destroy() 销毁线程池,该方法保证在所有任务都完成的情况下才销毁所有线程,否则等待任务完成才销毁

  • public int getWorkThreadNumber() 返回工作线程的个数

  • public int getFinishedTasknumber()
    返回已完成任务的个数,这里的已完成是只出了任务队列的任务个数,可能该任务并没有实际执行完成

  • public void addThread() 在保证线程池中所有线程正在执行,并且要执行线程的个数大于某一值时。增加线程池中线程的个数

  • public void reduceThread()
    在保证线程池中有很大一部分线程处于空闲状态,并且空闲状态的线程在小于某一值时,减少线程池中线程的个数

以上是关于线程池的主要内容,如果未能解决你的问题,请参考以下文章

ThreadPoolExecutor线程池设计思路

Java 并发编程线程池机制 ( 线程池执行任务细节分析 | 线程池执行 execute 源码分析 | 先创建核心线程 | 再放入阻塞队列 | 最后创建非核心线程 )

线程队列,线程池,协程

.net开发中,为何将100多个任务放入线程池却只有一个线程顺序执行

11_线程池

11_线程池