【原创】标准I/O库函数的缓冲机制引发的问题

标准I/O库函数在应用层提供了缓冲机制,这点不同于系统调用函数。一般对于交互界面是行缓冲,对于文件是全缓冲。
这两种缓冲机制的差别可以通过一个小例子进行观察。

[@more@]

源代码:

#include
#include

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@fsever cuitao]# ./fork

Befor fork.

i=11

i=10
[root@fsever cuitao]#

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

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

Befor fork.

i=11

Befor fork.

i=10
[root@fsever cuitao]#


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

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7437037/viewspace-978052/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/7437037/viewspace-978052/

你可能感兴趣的:(【原创】标准I/O库函数的缓冲机制引发的问题)