浅谈线程池
- 线程池(英语:thread pool):一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护着多个线程,等待着监督管理者分配可并发执行的任务。这避免了在处理短时间任务时创建与销毁线程的代价。线程池不仅能够保证内核的充分利用,还能防止过分调度。可用线程数量应该取决于可用的并发处理器、处理器内核、内存、网络sockets等的数量。 例如,线程数一般取cpu数量+2比较合适,线程数过多会导致额外的线程切换开销。
- 任务调度以执行线程的常见方法是使用同步队列,称作任务队列。池中的线程等待队列中的任务,并把执行完的任务放入完成队列中。
C++11多线程总结
- 线程创建的极限数量一般为 2000 个。
线程创建数量建议
- 采用某些开发建议和指示来确保程序高效执行。
- 根据实际应用场景;考虑可能被阻塞的最大线程数量,即创建多余最大被阻塞(耗时任务)线程数量的线程。如,有100个线程可能处理耗时任务,启动 110 个线程就可以保证有空闲线程处理其它请求。
- 线程的创建数量尽量不要超过 500 个,尽量控制在 200 个之内。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。