如何使用boost::asio::io_service在c++ 11线程之间调度作业
How to use boost::asio::io_service to dispatch jobs between C++11 threads
我需要在多核架构上执行大量相对较短的任务。为此,我想使用固定大小的线程池和一些可靠的执行器实现。
我正在阅读关于boost::asio和io_service在这篇文章中如何在c++中使用boost创建线程池?但这使用boost线程,而在我的代码的许多地方使用c++11 thread_local修饰符局部变量(出于性能原因),因此我想我被迫使用c++11线程。
boost线程实现是否与c++11 thread_local变量兼容?在c++11线程中使用io_service::run方法是否安全,而不是boost::thread?
在c++11线程中使用io_service::run方法是否安全,而不是boost::thread?
是的,我使用std::thread
和boost::asio
,它工作得很好。我也用std::bind
代替boost::bind
。你可以在这里找到一个例子
boost线程实现是否与c++11 thread_local变量兼容?
我不知道这个,但是如果你使用std::thread
相关文章:
- 从不同线程使用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 循环中创建线程?