【发布时间】:2013-05-14 04:37:44
【问题描述】:
我有以下代码:
for(i=1; i<=2; i++)
{
fork();
printf("x ");
}
我计算出 x 应该打印 6 次:第一次迭代两次,第二次迭代 4 次。
相反,X 被打印了 8 次。为什么?
【问题讨论】:
-
fork() and output的可能重复
我有以下代码:
for(i=1; i<=2; i++)
{
fork();
printf("x ");
}
我计算出 x 应该打印 6 次:第一次迭代两次,第二次迭代 4 次。
相反,X 被打印了 8 次。为什么?
【问题讨论】:
因为缓冲。通常,stdout 是行缓冲的,所以
printf("x ");
不会立即将"x " 写入终端,而是写入输出缓冲区。这是在进程fork()s 时复制的,因此第二次迭代后的四个进程中的每一个在输出缓冲区中都有两个"x " [一个来自父级/在第一次迭代中分叉之前,一个来自第二次迭代]它退出,总共打印了 8 个 xs。
在printf("x "); 之后立即刷新缓冲区,只会打印六个。
【讨论】:
fflush(stdout); 是在这里遵循 Daniel 建议的最简单方法。