c – 为了执行TBB?
发布时间:2020-12-16 09:41:05 所属栏目:百科 来源:网络整理
导读:我希望有类似于 tbb::task_group 的东西但是在订单执行方面保证不同,例如 serial_task_group tasks;tasks.run([]{std::cout 1;});tasks.run([]{std::cout 2;});tasks.run([]{std::cout 3;});tasks.wait();// guaranteed output: 123 有关如何使用tbb实现此目
我希望有类似于
tbb::task_group 的东西但是在订单执行方面保证不同,例如
serial_task_group tasks; tasks.run([]{std::cout << 1;}); tasks.run([]{std::cout << 2;}); tasks.run([]{std::cout << 3;}); tasks.wait(); // guaranteed output: 123 有关如何使用tbb实现此目的的任何建议? 目前我有一个显式线程,只使用条件变量从队列执行.但是,使用队列的问题是我如何保证 解决方法
(披露:我在英特尔处理英特尔线程构建模块.)
正如在另一个答案中所建议的那样,您可以使用流程图来执行此类操作.使用流程图的示例代码如下所示: #include "tbb/flow_graph.h" #include <iostream> using namespace tbb::flow; int main( int argc,char *argv[] ) { graph g; continue_node< continue_msg > n1( g,[]( const continue_msg & ) { std::cout << "1"; } ); continue_node< continue_msg > n2( g,[]( const continue_msg & ) { std::cout << "2"; } ); continue_node< continue_msg > n3( g,[]( const continue_msg & ) { std::cout << "3"; } ); make_edge( n1,n2 ); make_edge( n2,n3 ); n1.try_put( continue_msg() ); g.wait_for_all(); return 0; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |