【发布时间】:2016-01-20 15:52:47
【问题描述】:
我正在创建一个具有动态线程数的程序。我有一个线程向量(感谢 Mohamad);然后我尝试调用一个函数并为执行线程传递多个参数。
但是,我当前的代码给出了一个错误,我认为这是由于我奇怪地使用了 2D 数组:
In function 'int main()': 102 77 [Error] no matching function for call to 'std::thread::thread(void (&)(float ()[2], float, int, int), 浮动 [(((sizetype)(((ssizetype)nodeNumber) + -1)) + 1)][2], 浮动 [(((sizetype)(((ssizetype)nodeNumber) + -1)) + 1)], int&, int&)'
102 77 [注] 候选人为:4 0
133 7 c:\程序文件 (x86)\dev-cpp\mingw64\lib\gcc\x86_64-w64-mingw32\4.8.1\include\c++\thread [注意] 模板 std::thread::thread(_Callable&&, _Args&& ...)
133 7 c:\程序文件 (x86)\dev-cpp\mingw64\lib\gcc\x86_64-w64-mingw32\4.8.1\include\c++\thread [注意] 模板参数推导/替换失败:
102 77 【注意】变长数组类型'float (&)[(((sizetype)(((ssizetype)nodeNumber) + -1)) + 1)][2]' 不是 有效的模板参数
4 0 在包含自
的文件中128 5 c:\程序文件 (x86)\dev-cpp\mingw64\lib\gcc\x86_64-w64-mingw32\4.8.1\include\c++\thread [注意] std::thread::thread(std::thread&&)
128 5 c:\程序文件 (x86)\dev-cpp\mingw64\lib\gcc\x86_64-w64-mingw32\4.8.1\include\c++\thread [注意] 候选人需要 1 个参数,提供 5 个
122 5 c:\程序文件 (x86)\dev-cpp\mingw64\lib\gcc\x86_64-w64-mingw32\4.8.1\include\c++\thread [注意] std::thread::thread() 122 5 c:\程序文件 (x86)\dev-cpp\mingw64\lib\gcc\x86_64-w64-mingw32\4.8.1\include\c++\thread [注意] 候选人需要 0 个参数,提供 5 个
以下是我尝试这样做的一些代码块:
#include <iostream>
#include <fstream>
#include <string>
#include <thread>
#include <vector>
using namespace std;
void map(float rank_matrix[][2], float adjacency_matrix[], int nodeNumber, int node);
int main() {
// setup code, initialization section here
float adjacency_matrix[nodeNumber][nodeNumber];
float rank_matrix[nodeNumber][2];
while(iter < terminate) {
vector<thread> threads;
for(int i = 0; i < nodeNumber; i++) {
threads.push_back(std::thread(map, rank_matrix, adjacency_matrix[i], nodeNumber, i);
}
for(int i = 0; i < nodeNumber; i++) {
threads.join();
}
// Flush out the mass for each node (will be updated based on mapper's work.
for(i = 0; i < nodeNumber; i++) {
rank_matrix[i][0] = 0;
}
iter++;
cout << endl;
cout << endl;
}
return 0;
}
// Mapper code for each individual node and computation.
void map(float rank_matrix[][2], float adjacency_matrix[], int nodeNumber, int node) {
for(int i = 0; i < nodeNumber; i++) {
if(rank_matrix[node][1] != 0 && adjacency_matrix[i] > 0)
adjacency_matrix[i] = (rank_matrix[node][0] / rank_matrix[node][1]);
}
}
关于我做错了什么有什么建议吗?帮助将不胜感激!谢谢!
【问题讨论】:
-
我为您编辑了错误消息。您始终可以选择要阻止引用的所有内容,然后按“按钮
-
谢谢,下次我会努力记住的!
标签: c++ multithreading stdthread