线程池是一种多线程处理方式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。如果某个线程在托管代码中空闲(如正在等待某个事件),则线程池将插入另一个辅助线程来使所有处理器保持繁忙。如果所有线程池线程都始终保持繁忙,但是队列中包含挂起的工作,那么线程池将在一段时间后创建另一个辅助线程但是线程的数目永远不会超过最大值。超过最大值的线程可以排队,但是他们要等到其他线程完成后才可以启动。
线程池的组成主要分为3个部分,这三个部分配合工作就可以得到一个完整的线程池:
(1)任务队列:存储需要处理的任务,由工作的线程来处理这些任务
1.通过线程池提供的API函数,将一个待处理的任务添加到任务队列,或者从任务队列中删除
2.已处理的任务会被从任务队列中删除
3.线程池的使用者,也就是调用线程池函数往任务队列中添加任务的线程就是生产者线程
(2)工作的线程(任务队列任务的消费者)有多个
1.线程池中维护了一定数量的工作线程,他们的作用是不停的读任务队列,从里边取出任务并处理
2.工作的线程相当于是任务队列的消费者角色
3.如果任务队列为空,工作线程将会被阻塞
4.如果阻塞之后有了新的任务,由生产者将阻塞解除,工作线程开始工作。
(3) 管理者线程(不处理任务队列中的任务)1个
它的任务是周期性的对任务队列中的任务数量以及处于忙状态的工作线程个数进行检测
当任务过多的时候,可以适当创建一些新的工作线程。
当任务过少的时候,可以适当的销毁一些新的工作线程。
标签:工作,队列,处理,任务,线程,原理,多线程 From: https://www.cnblogs.com/huwy-123/p/18517793