线程池

来源:互联网 发布:大数据分析系统架构 编辑:程序博客网 时间:2024/05/18 01:17

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

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

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

  • 线程管理器(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()
    在保证线程池中有很大一部分线程处于空闲状态,并且空闲状态的线程在小于某一值时,减少线程池中线程的个数

1 0
原创粉丝点击