文件缓冲区的资源位于用户空间,因此,在创建子进程时,子进程的用户空间将复制父进程的用户空间的所有信息,显然,也包含流缓冲区的内容。如果流缓冲区中有临时的信息,则同样复制到子进程的用户空间流缓冲中
#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
int main(void)
{
pid_t pid;
//没有回车,先输出
printf("before fork,have enter\n");
//没有回车,缓存到输出流缓冲区
printf("before fork,no enter:pid=%t\t",getpid());
pid=fork();
if(pid==0)
printf("\nchild,after fork:pid=%d\n",getpid());//子进程输出
else
printf("\nparent,after fork:pid=%d\n",getpid());//父进程输出
}
运行结果如下:
before fork,have enter
//子进程中输出,但pid为父进程值,显然在fork前执行
before fork,no enter:pid=2532
child,after fork:pid=2533
//父进程输出,因为能有回车,在fork后的流刷新后输出
before fork,no enter:pid=2532
parent,after fork:pid=2532
从以上运行结果来看,子进程和父进程都输出了“before fork,no enter:pid=2532”,但是,显然子进程的pid不是2532,另外,子进程开始执行的位置是fork函数返回处,是不会执行fork函数之前的代码,虽然该代码被复制到子进程中。之所以出现两次输出,是因为父亲进程在fork前输出的第2个printf函数没有回车,而输出流是带缓冲的,从而该信息缓存到用户空间,创建子进程时,该信息被复制到子进程空间中,而子进程刷新了输出流缓冲区,从而将该信息输出。