我是线程编程的新手,我正在开发一个小练习,这里是练习文本:
使用实现两个矩阵的乘积的Pthreads编写C程序。 主线程创建nr1 * nc2线程,每个线程执行其计算。 最后主线程打印产品矩阵。
这是我的程序,使用C语言编写
#include <stdio.h>
#include <pthread.h>
#include <stdlib.h>
#define N 3
typedef struct {
int rm1;
int cm2;
} tipe_rc;
int matr1[N][N], matr2[N][N], result[N][N];
void * multiply_matrix(void *arg);
int main(int argc, const char * argv[]) {
int matr1[N][N], matr2[N][N], i, j, k=0;
pthread_t matr_pthread[N][N];
void* retval;
tipe_rc *trc;
// fill the two matrix
for (i=0; i<N; i++) {
for (j=0; j<N; j++) {
matr1[i][j] = k++;
}
}
for (i=0; i<N; i++) {
for (j=0; j<N; j++) {
matr2[i][j] = k++;
}
}
// start the thread computation
for (i=0; i<N; i++) {
for (j=0; j<N; j++) {
trc = malloc(sizeof(tipe_rc));
trc->rm1 = i;
trc->cm2 = j;
pthread_create(&matr_pthread[i][j], NULL, multiply_matrix, (void*) trc);
}
}
// rejoin all the threads
for (i=0; i<N; i++) {
for (j=0; j<N; j++) {
pthread_join(matr_pthread[i][j], &retval);
}
}
// print result matrix
for (i=0; i<N; i++) {
for (j=0; j<N; j++) {
printf("%d ", result[i][j]);
}
printf("\n");
}
return 0;
}
void * multiply_matrix(void *arg) {
int i=0;
tipe_rc *trc = (tipe_rc*) arg;
result[trc->rm1][trc->cm2] = 0;
for (i=0; i<N; i++) {
result[trc->rm1][trc->cm2] += matr1[trc->rm1][i] * matr2[i][trc->cm2];
}
return NULL;
}
代码似乎很容易且很直接,但不知怎的,我设法遇到了两个矩阵的一些问题。
问题
基本上,当我尝试在线程中使用矩阵 matr1 和 matr2 时,矩阵似乎是空的(所有值都为零),同时一旦在main()中生成了两个矩阵,它们就会得到正确的值。
为什么? 我根据进程和生成的线程之间的共享内存空间做错了吗?
答案 0 :(得分:2)
您有两个的matr1
和matr2
个变量。一组在全局级别,一组在main
函数内部是局部的,然后阴影全局变量。
由于线程使用全局变量,它们将全为零(因为全局变量初始化为零)。
简单的解决方案是不重新声明main
函数内的变量。