ERROR: std::thread arguments must be invokable after conversion to rvalues

ERROR: std::thread arguments must be invokable after conversion to rvalues

我正在尝试构建这个相对简单的代码,但由于标题中提到的错误而失败。我已经看过代码几次,但未能弄清楚是什么愚蠢导致了这种情况。有人可以给点提示或线索吗?

#include <thread>
#include <iostream>
#include <vector>
#include <chrono>
#include <mutex>
#include <functional>


std::vector<std::vector<double>> v2d;

int fill_the_vec(std::vector<double>& inp, int sz){
    for(int i = 0; i < sz; i++)inp.push_back(i * 2.0);
    return 0;
}

int fill_vec_mt(int r, int c){
    for(int i = 0; i < r; i++)v2d.push_back({});
    std::vector<std::thread> tv;

    for(int i = 0; i < r; i++){
        tv.emplace_back((fill_the_vec, std::ref(v2d[i]), c));
    }
    for (auto &t : tv)
        if(t.joinable())
            t.join();
    return 0;
}

int main(){
    
    fill_vec_mt(10, 1000);

    for(int i = 0; i < v2d.size(); i++){
        double t = 0;
        for(int j = 0; j < v2d[i].size(); j++){
            t += v2d[i][j];
        }
        std::cout <<  "Sum at place " << i << "is " << t << std::endl;
    }

    return 0;
}

你的说法

tv.emplace_back((fill_the_vec, std::ref(v2d[i]), c));

正在调用 comma operator,它计算其左参数,然后 returns 计算其右参数。因此,fill_the_vecstd::ref(v2d[i]) 将被评估和丢弃,然后

tv.emplace_back(c)

将被评估,这将不起作用,因为 c 不可调用。

要解决此问题,请删除多余的括号:

tv.emplace_back(fill_the_vec, std::ref(v2d[i]), c);

这将 3 个参数传递给 emplace_back,如您所愿。