我希望有类似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实现此目的的任何建议?
目前我有一个显式线程,只使用条件变量从队列执行。但是,使用队列的问题是我如何保证 在task_group中只有一个任务是活动的。
答案 0 :(得分:7)
(披露:我在英特尔处理英特尔线程构建模块。)
正如另一个答案中所建议的那样,您可以使用流程图来执行此类操作。使用流程图的示例代码如下所示:
#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;
}