apue有點激動的寫下這個大神的東東,膜拜您啊!!

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







發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章