在C++11线程中通过引用传递;更改是本地化的

passing by reference in C++ 11 threads; changes are localized

本文关键字:本地化 线程 C++11 引用      更新时间:2023-10-16

我正试图使用C++11线程加快对opencv代码的一些处理。

与此同时,我正在使用矢量共享数据

请考虑以下代码:

start_t = cv::getTickCount();
std::vector <std::thread>   tMSE_Calc(nComparisons);
std::vector<float> sum;
sum.resize(nComparisons);
for(int i = 0 ; i < nComparisons ; ++i)
{
    tMSE_Calc[i] = std::thread(FindMSE_Fast, vector1, vector2, sum, i);
}
for(int i = 0 ; i < nComparisons ; ++i)
{
    tMSE_Calc[i].join();
}
end_t = cv::getTickCount();
logfile << "Actual Comparison Took " << (end_t - start_t) * freq * 1000 << " milliseconds"<< std::endl;
for(int i = 0 ; i < nComparisons ; ++i)
{
    std::cout << "Sum[" << i << "] = " << sum[i] << std::endl;
}

我有一个线程函数:

void FindMSE_Fast(cv::Mat& m1, cv::Mat& m2, std::vector<float>& sumVec, int idx)
{
    cv::Mat s;
    cv::absdiff(m1, m2, s);
    s = s.mul(s);
    cv::Scalar sum = cv::sum(s);
    sumVec[idx] = cv::sqrt(sum[0]);
    std::cout << "Difference is: " << cv::sqrt(sum[0]) << "index is: " << sumVec[idx] << std::endl;
    //std::cout << "Difference is: " << cv::sqrt(sum[0]) << std::endl;
}

在我看来,向量和应该在线程调用结束时修改,但当我稍后在主线程中打印它时,它的所有内容都为零。

为了通过引用传递,我们需要对函数参数进行哪些不同的处理?

绑定的函数参数是复制的,不会通过引用传递。这种行为与std::bind()相同。参数作为推导的T&&传递给构造函数,但这仅用于初始化某些保留值。

如果你不想复制参数,你可以传递一个std::reference_wrapper<T>,例如,使用

std::thread(FindMSE_Fast, vector1, vector2, std::ref(sum), i)

而通过参考CCD_ 5。由于std::reference_wrapper<T>有一个到T&的转换运算符,您的函数将被适当地调用。