我正在尝试使用pthreads编写一个简单的parallel_for。 原始代码是这样的。
#ifdef HAVE_TBB
template<typename Body> static inline
void parallel_for( const BlockedRange& range, const Body& body )
{
tbb::parallel_for(range, body);
}
#else
template<typename Body> static inline
void parallel_for( const BlockedRange& range, const Body& body )
{
body(range);
}
#endif
我重写了TBB不存在的情况。这是我写的。我有编译问题。 threadFunc在我之前写template<typename Body>
时会出错。
In function 'void cv::parallel_for(const cv::BlockedRange&, const Body&)':
error: no matches converting function 'threadFunc' to type 'void* (*)(void*)'
error: candidates are: template<class Body> void* cv::threadFunc(void*)
这些是我收到的错误消息。必须有一个简单的修复。感谢。
struct MyStruct {
BlockedRange range;
Body& body;
};
//template<typename Body>
static void* threadFunc(void *arg) {
MyStruct<Body> *rangeBody = (MyStruct<Body>*) arg;
rangeBody->body(rangeBody->range);
}
template<typename Body> static inline
void parallel_for( const BlockedRange& range, const Body& body )
{
BlockedRange& range1 = BlockedRange(range.begin(), range.end()/2);
BlockedRange& range2 = BlockedRange(range.end()/2, range.end());
MyStruct<Body> rangeBody1;
rangeBody1.range = range1;
rangeBody1.body = body;
MyStruct<Body> rangeBody2;
rangeBody2.range = range2;
rangeBody2.body = body;
pthread_t thread1, thread2;
pthread_create(&thread1, NULL, threadFunc, (void*) &rangeBody1);
pthread_create(&thread2, NULL, threadFunc, (void*) &rangeBody2);
pthread_join( thread1, NULL);
pthread_join( thread2, NULL);
}
答案 0 :(得分:4)
如果threadFunc
是一个函数模板,那么您需要将其专门化以获得所需的函数:
pthread_create(&thread1, NULL, threadFunc<Body>, &rangeBody1);
^^^^^^