我正在做分配,要求并行使用10个进程求和两个数组,所以我写了这个代码,我使用管道到父级和子级之间的IPC,但它给我分段错误,当它想从管道读取。
#include <stdlib.h>
#include<stdio.h>
struct s {
int * x ;
int max , min ;
} ;
void sum(int *a , int *b , struct s w , int min , int max , int pipe)
{
int i ;
for(i = min ; i < max ; i++)
{
*(w.x+i) = *(a+i)+*(b+i) ;
}
write(pipe , w , sizeof(w)) ;
}
int main()
{
int i ,min = 0 ,max = 1 ;
int a[11] = {1,1,1,10,1,1,1,1,1,1,1} ;
int b[11] = {1,1,1,10,1,1,1,1,1,1,1} ;
int c[11];
int fd[2] ;
int j ;
pipe(fd) ;
for(i = 0 ; i < 10 ; i++)
{
int pid = fork();
if(pid == 0)
{
struct s w ;
w.max = max ;
w.min = min ;
*w.x = c[0] ;
close(fd[0]) ;
sum(a,b,w,min , max , fd[1]);
printf("Done %d n" , i);
exit(0);
}
else
{
min++;max++;
}
}
struct s w ;
for(j = 0 ; j < 10 ; j++)
{
//segmentation fault !!
read(fd[0] , w ,sizeof(struct s)) ;
for(i = w.min ; i < w.max ; i++)
{
printf("[%d] --> %d n" ,i , *(w.x+i) ) ;
}
}
return 0;
}
你知道吗?
read()第二个参数需要一个地址。使用,w
的地址操作符
read(fd[0] , &w ,sizeof(struct s)) ;