#include <unistd.h>
#include <stdio.h>
int glob = 6;
char buf[] = "a write to stdout\n";
int main()
{
int var;
pid_t pid;
var = 88;
if (write(STDOUT_FILENO, buf, sizeof(buf)-1) != sizeof(buf)-1)
printf("%m\n"), exit(-1);
printf("before fork\n");//1
if ((pid = fork()) < 0) {
printf("%m\n"), exit(-1);
} else if (pid == 0) {
glob++;
var++;
} else {
sleep(2);
}
printf("pid = %d, glob = %d, var = %d\n", getpid(), glob, var);//2
exit(0);
}
我在这里拼命的呐喊,是因为,这个例子真的很好。我的着眼点不是最后一个printf//2,而是printf//1.
我直接进入重点:
./a.out得到的输出结果是:
a write to stdout
before fork
pid = 430, glob = 7, var = 89
pid = 429, glob = 6, var = 88
./a.out > 1.txt的输出结果是:
a write to stdout
before fork
pid = 430, glob = 7, var = 89
before fork
pid = 429, glob = 6, var = 88
分析:
在我机器上也有这个结果,当然pid不同。1,为什么write没有打印两次呢?
因为write是没有缓冲的,所以,直接就flush掉喽~2,为什么./a.out>1会多打印一行printf的内容呢?
因为printf因时而变,当是输出到终端的话,那么就是行缓冲,flush掉喽~如果输出到文件则是全缓冲,则fork的时候也会把这部分缓冲内容复制到子进程中喽~
或者,你把printf//1从
printf("before fork\n");//1
改为:
printf("before fork");//1
也可以得到重定向到文件的类似效果。