Linux下fork函数的使用

fork函数每调用一次,函数返回两次,新进程(子进程)中返回0,原进程(父进程)中返回子进程的pid。

Q:为什么不是子进程中返回父进程pid,父进程中返回0呢?

那是因为一个父进程有很多子进程,如果不返回其特定子进程的pid,之后需要调用其子进程时就找不到这个子进程了;而一个子进程只有一个父进程,如果要看其父进程的pid只需要通过调用getppid()函数即可。

举一个简单的例子
代码如下图
这里写图片描述

代码实现过程分析
这里写图片描述

在Linux gcc环境下的执行结果为
这里写图片描述

由此延伸几个fork函数的应用

例一:

void main()
{
    int i = 0;
    for(;i<2;i++)
    {
        if(fork())
            printf("A\n");
        else
            printf("B\n");
    }
}

执行一次结果:AABBAB
执行两次结果:AABABB
… …
执行n次结果:总是包含3个A,3个B

代码执行过程分析

这里写图片描述

注:fork函数调用之后,哪个进程优先执行,与操作系统的进程调度算法和当前计算机环境有关,打印出来的先后是不定的。

例二:

void main()
{
    if(fork() || fork())
        printf("A\n");
    else
        printf("B\n");
}

执行结果:AAB

代码执行过程分析

这里写图片描述

注: 1||1 = 1;1 || 0 = 1;0 || 1 = 1;0 || 0 = 0
当“||”前为1时,则不用判断后面一个;如果“||”之前为0,继续执行后面表达式。

例三:

void main()
{
    int i = 0;
    for(;i<2;i++)
    {
        if(fork())
            printf("A");
        else
            printf("B");
    }
}

执行一次结果:AAABBABB
… …
执行n次结果:总是包含4个A,4个B

代码执行过程分析

这里写图片描述

注:当printf中没有"\n"时,缓冲区无法刷新,每个PCB的缓冲区都将保留函数返回的结果,当i = 1时,所产生的子进程将缓冲区也复制过来,因此,例三程序相对于例一就多出了一个A和一个B。

最后,在例三函数显示父进程的执行过程中会出现孤儿进程,所谓孤儿进程就是说父进程已经结束,而子进程未结束,其子进程就成为了孤儿进程。

pid_t getpid()    //得到pid
ppid_t getppid()  //得到ppid

解决孤儿进程的方法:让父进程在子进程结束之前进入睡眠状态,即父进程在子进程结束之前不会结束。

# define a 5

sleep(a--);
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值