【发布时间】:2015-09-04 22:21:17
【问题描述】:
这是我针对这种情况的代码。基本上,我有很多孩子,他们应该从 ptList 计算一定数量的点,将各自的点传递给父母,然后父母将它们相加。不幸的是,使用我的 printfs,“addToTotal”变量没有更新到第一个孩子之后,我的回答不正确。任何建议都会令人难以置信。
pid_t worker[ workers ];
for (int i = 0; i < workers; i++) {
//printf( "I am child %i\n", i );
if ((worker[i] = fork()) < 0) {
fail( "Can't create child");
} else if ( worker[i] == 0) {
//Close the reading end of the pipe for each child
close( pfd[0] );
// Get each of the workers to compare points
for ( int k = i; k < ptCount; k += workers ) {
for ( int j = k + 1; j < ptCount; j++) {
int dx = ptList[ k ].x - ptList[ j ].x;
int dy = ptList[ k ].y - ptList[ j ].y;
if ( dx * dx + dy * dy <= dsq )
childTotal++;
}
}
printf( "Child %i total: %i\n", i, childTotal );
lockf( pfd[ 1 ], F_LOCK, 0 );
write( pfd[ 1 ], &childTotal, sizeof( childTotal ));
lockf( pfd[ 1 ], F_ULOCK, 0 );
close( pfd[ 1 ] );
exit(0);
wait(NULL);
}
wait(NULL);
close( pfd[ 1 ] );
read( pfd[ 0 ], &addToTotal, sizeof( addToTotal ) );
printf( "AddToTotal: %i\n", addToTotal );
total += addToTotal;
}
【问题讨论】:
-
在循环的第一次迭代中,父级关闭管道的写入端。在第二次迭代中,子进程继承了一个写端关闭的管道。
标签: c multithreading pipe inter-process-communicat