Multiplicando 2 matrices 2D usando Fork ()
-
13-12-2019 - |
Pregunta
Estoy tratando de multiplicar un [2] [3] con B [3] [4] y poner la respuesta en C [2] [4]. Tengo que usar FORK () y hacer 2 procesos, cada niño para C [0] [J] y C [1] [J], los padres esperarán. Por lo que cada proceso de niño calculará una fila para c.Este es mi código:
//multiply a[2][3] * b[3][4] = c[2][4]
//with fork
//each child completes one c[2][4]'s row
#include<stdio.h>
#include<stdlib.h>
main()
{
int a[2][3]={1,2,3,
4,5,6};
int b[3][4]={1,2,3,4,
5,6,7,8,
9,10,11,12};
int c[2][4];
int i,j;
int m; //for the calculation
int n; //common 3
int pid; //fork
for(i=0;i<2;i++)
{
pid=fork();
if(pid==-1)
{
printf("Can't fork\n");
}
if(pid==0)//child
{
for(j=0;j<4;j++)
{
for(n=0;n<3;n++)
{
m=m+a[i][n]*b[n][j];
}
c[i][j]=m;
m=0;
}
exit(EXIT_SUCCESS);
}
if(pid>0)//parent
{
wait(0);
}
}
printf("C:\n");
for(i=0;i<2;i++)
{
for(j=0;j<4;j++)
{
printf("%d\t",c[i][j]);
}
printf("\n");
}
}
No tengo errores en la compilación, pero tengo números equivocados ... Grandes números incómodos ... ¿Alguna idea?
Solución
Q: No tengo errores en la compilación, pero tengo números equivocados ... incómodo Grandes números ... ¿Alguna idea?
A: Sí: el momento en que se sujeta, tiene dos procesos diferentes con dos espacios de direcciones completamente independientes :)
Una buena solución es usar hilos en lugar de tenedor ():
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow