Intel tbb parallel_for:用参数传递类成员函数?

时间:2014-11-01 13:13:50

标签: c++ multithreading tbb

是否可以将类成员函数(带参数)传递给parallel_for?一些事情:

void classT::A(const tbb::blocked_range<std::size_t>& r,b) {}

void classT::B(e,f,g) { 
   tbb::parallel_for( blocked_range<size_t>(0,n), <need to call A with parameter b, 
                                                                       along with r> ) 
}

1 个答案:

答案 0 :(得分:1)

请看this example

他们创建了一个类,并使用所需的所有参数来提供类。 在该类中,还有一个operator(),它对数据进行操作。 然后使用该类的实例调用parallel_for。

parallel_for(blocked_range<int>(0, nElements, 100), ArraySummer( p_A, p_B, p_SUM_TBB ) ); 
//The class is arraysummer

你怎么做:

class ClassTACaller
{
   int* m_parameter;
   ClassT* m_Tinstance

public:

   ClassTACaller(ClassT* tinstance, int* param):m_parameter(param), m_Tinstance(tinstance){}
   void operator() ( const blocked_range<int>& r ) const 
   {
      m_Tinstance->A(r, param);
   }
};

parallel_for(blocked_range<int>(0, nElements, 100), ClassTACaller(&classTinstance, &x));