当我尝试使用QtConcurrent :: map实现“ parallel for”时
QFuture<void> parForAsync(size_t n, std::function<void (size_t)> Op)
{
size_t nThreads =
static_cast<size_t>(QThreadPool::globalInstance()->maxThreadCount());
size_t nn = n/nThreads + 1;
using Sequence = QVector<std::function<void()>>;
Sequence vFuns;
for(size_t i = 0; i < n; i+=nn)
{
size_t firstIdx = i,
lastIdx = i + nn > n ? n : i + nn;
vFuns.push_back([=]()->void
{
for(size_t i = firstIdx; i < lastIdx; ++i)
{
Op(i);
}
});
}
return QtConcurrent::map<Sequence> //<-Segmentation fault!
(vFuns, [](std::function<void()> f)
{
f();
});
}
我在这个地方出现了细分错误:
template<typename _Res, typename... _ArgTypes>
function<_Res(_ArgTypes...)>::
function(const function& __x)
: _Function_base()
{
if (static_cast<bool>(__x))
{
__x._M_manager(_M_functor, __x._M_functor, __clone_functor); //<-Segmentation fault!
_M_invoker = __x._M_invoker;
_M_manager = __x._M_manager;
}
}
为什么会这样?似乎std :: function已通过检查。如何使此代码正常工作?
谢谢!
答案 0 :(得分:2)
我无法复制您的案子,但我可以举一些例子来说明问题
QFuture<void> test ()
{
QVector<int> v; // LOCAL VARIABLE IN SCOPE OF test FUNCTION
// preparing v vector
QFuture<void> f = QtConcurrent::map(v,someFunction); // returns immediately
return f;
}
[1] QtConcurrent::map
通过引用NOT BY COPY取得了v
。
[2] QtConcurrent::map
立即返回。
[3]因此,当test
函数结束时,由map
开始的并行操作将使用v
向量,该向量已删除,因为它是test
函数中的局部变量。>
您可以将waitForFinished
用于QFuture
,但是您的函数没有意义,因为它会阻塞直到并行任务结束。