自己的写的看法:
- 有一个Pool类,内部管理任务(job)的分发。维护任务队列和线程队列(忙碌和空闲),并创建一个分发线程(专门用于任务的分发)。这个分发线程会调用分发函数,分发任务队列中的任务。
- 当添加一个新任务的时候(CThreadManage->Run()方法添加任务),Pool会将这个新任务添加到任务队列中。添加后任务不一定立即执行,而是等待线程池中的分发线程进行分发。
- 分发线程会将 任务队列中的任务添加到空闲线程队列中的空闲线程上,并唤醒阻塞的工作线程,以执行相应的工作。
- 工作线程被唤醒后,会执行工作线程类的run()函数,在此函数中调用m_Job->Run(),用多态实现不同的任务加载到同一个工作线程类上的操作。
- 因为做完了添加任务的工作,所以此时的这个线程是忙碌的,所以应该将此线程从空闲链表中移除,并加入到忙碌线程链表中。
- 工作线程完成任务后,将自己放回空闲线程链表,并判断空闲线程个数,如果过多,这说明线程冗余,适当删除线程释放资源。
- 利用循环继续进入阻塞,等待下一个任务到来。
-
详细说明如下:
基本思路:管理一个任务队列,一个线程队列,然后每次取一个任务分配给一个线程去做,循环往复