0

我有一段代码tbb::parallel_for用于多线程循环,由主线程调用。在那个循环中,我需要主线程来更新 UI 以反映进度。根据我的观察,tbb::parallel_for总是使用调用者线程 + N 个工作线程。但是,我想知道,调用线程的使用是否得到保证,或者恰好是这种情况?

这是示例代码:

static thread_local bool _mainThread = false;  // false in all threads
_mainThread = true;                            // now true in main thread, but false in others
tbb::parallel_for(start, end, *this);

void Bender::processor::operator()(size_t i) const
{
...
            if(_mainThread)                     // only main thread will issue events
                ProgressUpdatedEvent(progress);
}

谢谢!

4

1 回答 1

2

严格来说,我不认为 TBB 对任何给定线程应该运行什么有任何保证(TBB 的基本原则是可选并行性和随机工作窃取)。甚至 TBB 中的任务关联也是“软的”,因为不能保证特定的工作人员可以执行关联任务。

实际上,parallel_for 的实现方式意味着它将运行至少一个任务,然后再切换到其他任务并退出 parallel_for。因此,至少对于简单的情况,它应该工作得很好。

于 2017-04-21T22:13:24.767 回答