2017-03-09 49 views
-1

我正在C语言中进行矩阵乘法,特别是使用pthread。这是我的代码。它运行失败,它只打印一次空矩阵并表示分段错误。任何人都可以指出错误吗?谢谢。C中的多线程矩阵乘法

#include <pthread.h> 
#include <stdlib.h> 
#include <stdio.h> 

#define NUM_THREADS 9 
int A[3][3] = {{2,5,6},{2,12,10},{6,1,8}}; 
int B[3][3] = {{7,5,1},{17,0,13},{3,2,5}}; 
int answer[3][3]={0}; 

void *multiply (void *param); 
void print_matrix (int m[3][3]); 

void print_matrix (int m[3][3]) { 
    int i, j; 
    for (i = 0; i < 3; i++) { 

      for (j = 0; j < 3; j++) 
      printf("%d\t ", m[i][j]); 
    printf("\n"); 
    } 
} 

void *multiply (void *param) { 
    int i, j, k; 
    for(i = 0; i < 3; i++) 
    { 
      for(j = 0; j < 3; j++) 
      { 
        for(k = 0; k < 3; k++) 
        { 
          answer[i][j] += A[i][k] * B[k][j]; 
        } 
      } 
    } 
    pthread_exit(NULL); 
} 

int main() 
{ 
    pthread_t tid[NUM_THREADS]; 
    int i, j; 
    for (i = 0; i < NUM_THREADS; i++) { 
     pthread_attr_t attr; /* set of attributes for the thread */ 
     pthread_attr_init(&attr);/* get the default attributes */ 
     pthread_create(&tid[i],&attr,multiply,NULL); 
    } 

    for (j = 0; j < NUM_THREADS; j++) { 
     pthread_join(tid[i],NULL); 
     print_matrix(answer); 
    } 


} 
+2

你是否自己做过任何调试?使用调试器和/或调试打印语句。你发现了什么? – kaylum

+0

你如何将你的数据传递给你的线程?由于9个线程同时处理相同的数据,您如何防止竞争条件?你如何确保你不会将这两个阵列乘以9次? –

+1

你为什么运行'multiply()'的9个线程做同样的事情并写在同一个变量上? – alvits

回答

0

您正在同时运行全部9个线程,这些线程正在访问相同的全局变量。这可能会造成问题。尝试在调用线程后施加一个小的时间延迟。 sleep(1);可以做到这一点。或者使用像互斥/信号量这样的机制