子进程对父进程文件缓冲区的处理

文件缓冲区的资源位于用户空间,因此,在创建子进程时,子进程的用户空间将复制父进程的用户空间的所有信息,显然,也包含流缓冲区的内容。如果流缓冲区中有临时的信息,则同样复制到子进程的用户空间流缓冲中

#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函数没有回车,而输出流是带缓冲的,从而该信息缓存到用户空间,创建子进程时,该信息被复制到子进程空间中,而子进程刷新了输出流缓冲区,从而将该信息输出。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值