c++中的线程池
Thread pooling in c++
我在一个线程池中有5个线程。如果我从一个用户那里得到10个请求,我将如何使用cpp处理每个线程的2个请求。我想动态处理请求。我的线程将保持不变,但请求可以是动态的,我还想显示线程执行的日志
线程池背后的理念是有固定数量的线程,当新的作业请求到来时,它将被分配给一个可用的线程。如果没有可用的线程(即所有线程都忙于处理其他作业(,则将作业请求添加到FIFO队列的末尾。每当线程处理完当前正在处理的作业请求时,它都会检查FIFO队列,看看作业请求是否在那里排队等待处理。如果FIFO中有作业请求,线程会将其从FIFO的头部弹出并处理;如果没有,线程将进入睡眠状态,直到出现下一个作业请求(此时,它或另一个线程将被线程池唤醒,以便可以处理新的作业请求(。
通过这种方式,可以使用有限数量的线程来处理任意数量的作业请求。
相关文章:
- 从不同线程使用int64的不同字节安全吗
- 删除一个线程上有数百万个字符串的大型哈希映射会影响另一个线程的性能
- 在C++中使用cURL和多线程
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 在cuda线程之间共享大量常量数据
- 如何将元素添加到数组的线程安全函数?
- 线程,如果else语句,都是错误的上下文切换后,会发生什么
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- Qt C++静态thread_local QNetworkAccessManager是线程应用程序的好选择吗
- 异常属于C++中的线程还是进程
- C++中的线程安全删除
- C++使用params创建线程函数会导致转换错误
- 类与私有变量的其他类之间的线程安全性
- CoInitialize()在单独的线程上崩溃而不返回
- c++中的线程池
- 线程之间的布尔停止信号
- 为什么std::async使用同一个线程运行函数
- 用于矢量处理的多个线程
- C++为线程工作动态地分割例程
- 为什么我不能在 while 循环中创建线程?