标准IO库的缓冲机制引起的问题

在介绍有缓冲机制I/O和无缓冲机制I/O的区别之前。先看一个例子预热一下,如果知道为什么,就说明关于两者的区别是很明了的,如果看到结果很吃惊,就说明还有一点偏差

#include <stdio.h>
#include <unistd.h>

int main()
{
int i=10,pid;

printf("nBefor fork.n");
fflush(stdout);

if((pid=fork())<0)
{
printf("nError fork!");
return 1;
}
else if(pid==0)
i++;
else
sleep(2);

printf("ni=%dn",i);
return 0;
}

当stdout 为显示屏的时候执行结果:

[root@localhost]# ./fork

Befor fork.

i=11

i=10
[root@localhost]#

当stdout为文件的时候执行结果:

[root@localhost]# ./fork > ./temp.txt
[root@localhost]# cat ./temp.txt

Befor fork.

i=11

Befor fork.

i=10


差别就在于这里有两个Befor fork. 语句。因为子进程继承了父进程的缓冲区,fork时父进程的缓冲区还没有被清空,
所以第一条输出语句就被复制到了子进程的缓冲区之中跟随下面的输出在return 的时候一起输出到文件。当stdout是
显示器的时候标准I/O库函数采取的是行缓存,所以没有出现两条Before fork. 输出。


你可能感兴趣的:(c,linux)