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?

¿Fue útil?

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 ():

https://computing.llnl.gov/tutorials/pthreads/

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top