C 线程编程中未正确获取全局变量
Global variables not correctly acquired in C thread programming
我是线程编程的新手,正在做一个小练习,练习原文如下:
Write a C program using Pthreads that implements the product of two matrices.
The main thread creates nr1*nc2 threads, every thread performs its computation.
Finally the main thread print the product matrix.
这是我的程序,用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() 中生成两个矩阵后,它们就会得到正确的值。
这是为什么?
根据进程和生成的线程之间的共享内存 space,我做错了什么吗?
您有 两个 matr1
和 matr2
变量。一组在全局级别,一组在 main
函数内部,然后 shadows 全局变量。
由于线程使用全局变量,它们将全部为零(因为全局变量是零初始化的)。
简单的解决方案是不要在 main
函数中重新声明变量。
我是线程编程的新手,正在做一个小练习,练习原文如下:
Write a C program using Pthreads that implements the product of two matrices. The main thread creates nr1*nc2 threads, every thread performs its computation. Finally the main thread print the product matrix.
这是我的程序,用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() 中生成两个矩阵后,它们就会得到正确的值。
这是为什么? 根据进程和生成的线程之间的共享内存 space,我做错了什么吗?
您有 两个 matr1
和 matr2
变量。一组在全局级别,一组在 main
函数内部,然后 shadows 全局变量。
由于线程使用全局变量,它们将全部为零(因为全局变量是零初始化的)。
简单的解决方案是不要在 main
函数中重新声明变量。