本章主要内容
- 线程池
- 处理池中任务的依赖关系
- 线程如何获取任务
- 中断线程
之前的章节中,通过创建std::thread
来对线程进行管理。一些情况下,这种方式不可行,因为需要在线程的整个生命周期中对其进行管理,并根据硬件来确定线程数量等等。理想情况是将代码划分为最小块再并发执行,之后交给处理器和标准库进行性能优化。
另一种情况,使用多线程来解决某个问题时,在某个条件达成时,可以提前结束。可能是因为结果已经确定,或者因为产生错误,亦或是用户执行终止操作。无论是哪种原因,线程都需要发送“停止”请求,放弃任务,清理,然后尽快停止。
本章我们将了解一下管理线程和任务的机制,从自动管理线程数量和自动管理任务划分开始。