#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
也可以得到重定向到文件的類似效果。