fork()函数的总结

fork函数包含在头文件 #include<unistd.h> 中

fork函数用于创建一个新进程,称为子进程,它与进程(称为系统调用fork的进程)同时运行,此进程称为父进程。创建新的子进程后,两个进程将执行fork()系统调用之后的下一条指令。子进程和父进程的执行顺序不确定,不是说谁一定先执行。

子进程使用相同的pc(程序计数器),相同的CPU寄存器,在父进程中使用的相同打开文件。 

fork函数是有返回值的,父进程的fork()的返回值是子进程的pid ,而子进程的fork()的返回值是 0(可以理解为子进程没有它的子进程所以返回值是0),还有可能返回值是 -1,这代表fork()出现了错误。

错误的原因有三种可能:

1) 系统内存不够

2) 进程表满(容量一般为 200~400)

3) 用户的子进程太多(一般不超过 25 个)

示例1:

#include<unistd.h>
int main(){
        pid_t fpid;
        int count = 0;
        fpid = fork();
        if(fpid<0){
                printf("Error !\n");
        }else if(fpid == 0){
                printf("Son process ! Pid = %d\n",getpid());
                count++;
        }else{
                printf("Father process ! Pid = %d\n",getpid());
                count++;
        }
        printf("count = %d\n",count);
        return 0;
}

结果: 

 

示例2:

#include<unistd.h>
#include<stdio.h>
int main(){
        int i = 0;
        for(i = 0;i < 3;i++){
                pid_t fpid = fork();
                if(fpid == 0)
                        printf("Son\n");
                else
                        printf("Father\n");
        }       
        return 0;
}      

结果:

实例3:

请画出一下代码运行后的进程关系

fork()
fork()
fork()
fork()

实例四:

 

要求父进程产生两个子进程,父进程输出从1到6 ,子进程1 输出从a 到 f ,子进程2 输出从 A 到 F,要求按aA1类似的交替输出

 

#include<stdio.h>
#include<unistd.h>
int main(){
        int p = fork();
        int q;
        if(p){
                q = fork();
                if(q){
                     int i=1;
                     printf("this is the father! Pid = %d\n", getpid());
                     while(i<=6){
                             printf("%d",i++);
                             fflush(stdout);
                             sleep(1);
                     }
                }else{
                     char c='a';
                     printf("this is child2 ! pid = %d\n" ,getpid());
                     while(c<='f'){
                             printf("%c\n",c++);
                             sleep(1);}
                }
        }else{
             char c='A';
             printf("this is child1 ! pid = %d\n",getpid());
             while(c<='F'){
                     printf("%c\n",c++);
                     sleep(1);}
        }
        return 0;
}

这里如果没有再输出后面加上"\n"的话是不会交替输出的,而还是整个进程整个进程的输出,当加上"\n"是才可以交替输出。这里"\n"的作用就是刷新行缓冲区,

行缓冲,大小是一行,加了回车就是一行了

Fflush(stdout)函数的作用也是清空缓冲区

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值