缓冲区的一些例子

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
int main()
{
        pid_t pid = 0;

        printf("test\n");

        pid = fork();
        if (pid == 0) {
                exit(0);
        }

        return 0;
}

上面这段代码运行的结果输出:

   test

但如果运行./fork > out.txt

你会发现在out.txt内容是:

test

test

这是因为pintf()函数自己维护了一个缓冲区,在输出到终端时,为行缓冲,而其他的情况下则是全缓冲。这样在输出到终端时,虽然fork出了新进程,但是因为是输出到终端,所有是行缓冲,输出一行后,刷新缓冲区并输出到屏幕,那么缓冲中在就没有任何数据了,所以在fork子进程退出后,虽然会刷新缓冲区,但是缓冲区没有内容,所有,只输出了一个test。但是当输出被重定向到out.txt时,那么printf()是全缓冲区,在父进程空间运行时,printf();的test并没有输出,而是保留在缓冲区中,当fork之后,产生子进程,我们知道子进程复制父进程的一切,只是换了一个进程ID。这样缓冲区的内容也被复制出来。这样在父进程退出时,刷新缓冲区,输出一个test,在子进程退出时,刷新缓冲区,我们刚才已经描述了,在fork子进程时,父进程的缓冲区也别完全复制过来,那么子进程的缓冲区中也有一个test,所以子进程也输出一个test。

当然在linux中要注意的是exit()和_exit()的区别,除了exit()要执行atexit()注册的退出函数外,还会比_exit()多做一个操作就是刷新缓冲区,

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
int main()
{
        pid_t pid = 0;

        printf("test\n");

        pid = fork();
        if (pid == 0) {
                _exit(0);
        }

        return 0;
}

改成上面这样后,编译在运行代码。在开始的例子中的两种方式运行代码,结果都只输出一个test。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值