QtConcurrent :: map分割错误

时间:2018-09-20 19:08:44

标签: qt qtconcurrent

当我尝试使用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已通过检查。如何使此代码正常工作?

谢谢!

1 个答案:

答案 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,但是您的函数没有意义,因为它会阻塞直到并行任务结束。