在C线程编程中未正确获取全局变量

时间:2015-01-08 13:21:22

标签: c multithreading matrix

我是线程编程的新手,我正在开发一个小练习,这里是练习文本:

  

使用实现两个矩阵的乘积的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()中生成了两个矩阵,它们就会得到正确的值。

为什么? 我根据进程和生成的线程之间的共享内存空间做错了吗?

1 个答案:

答案 0 :(得分:2)

您有两个matr1matr2个变量。一组在全局级别,一组在main函数内部是局部的,然后阴影全局变量。

由于线程使用全局变量,它们将全为零(因为全局变量初始化为零)。

简单的解决方案是不重新声明main函数内的变量。