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;
}

代码看起来简单明了,但不知何故,我遇到了两个矩阵的一些问题。

问题

基本上,当我尝试在线程中使用矩阵 matr1matr2 时,矩阵似乎是空的(所有值为零),同时在 main() 中生成两个矩阵后,它们就会得到正确的值。

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

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

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

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