我是fork(),父进程和子进程的新手,并且难以理解我编写的代码背后的逻辑,但没有达到我的预期。这就是我所拥有的:
int main (int argc, char** argv)
{
FILE *fp_parent;
FILE *fp_child;
fp_parent = fopen ("parent.out","w");
fp_child = fopen ("child.out","w");
int test_pid;
printf ("GET HERE\n");
fprintf (fp_parent,"Begin\n"); // MY CONCERN
for (int i = 0; i < 1; i++) //for simplicity, just fork 1 process.
{ // but i want to fork more processes later
test_pid = fork();
if(test_pid < 0)
{
printf ("ERROR fork\n");
exit (0);
}
else if(test_pid == 0) // CHILD
{
fprintf(fp_child,"child\n");
break;
}
else //PARENT
{
fprintf(fp_parent,"parent\n");
}
}
fclose(fp_parent);
fclose(fp_child);
}
所以上面代码的输出是:
to stdout: GET HERE
in parent.out:
Begin
parent
Begin
in child.out:
child
我主要担心的是,我不太明白为什么“开始”会被写入parent.out两次。如果我完全删除for循环,则只写入一个“Begin”,这是预期的。
所以我认为这是因为fork()而且我肯定想念或者不理解它背后的一些逻辑。你能帮我解释一下吗?
我的计划是能够在parent.out中的for循环之前写一些东西,并在parent.out中的for循环期间写一些东西。子进程将写入child.out。
答案 0 :(得分:4)
在C中,使用FILE
结构的输入/输出操作在用户进程级别进行缓冲。在您的情况下,您写入fp_parent
的输出实际上并未写入磁盘,而是在fork
时刻保存在本地缓冲区中。 fork
创建整个过程的副本,包括包含Begin
的缓冲区,这就是它在文件中出现两次的原因。尝试将fflush(fp_parent);
放在fork
之前。这将刷新缓冲区,脏线将从文件中消失。