zoukankan      html  css  js  c++  java
  • fork同一时候创建多个子进程的方法

    Fork同一时候创建多个子进程方法

     

     

    第一种方法:验证通过 

    特点:同一时候创建多个子进程。每一个子进程能够运行不同的任务,程序 可读性较好,便于分析,易扩展为多个子进程 

    int main(void) 

    printf("before fork(), pid %d ", getpid()); 

    pid_t p1 fork(); 

    if( p1 == )

    printf("in child 1, pid %d ", getpid()); 

    return 0; //若此处没有return p1 进程也会运行 pid_t p2=fork()语句

    pid_t p2 fork(); 

    if( p2 == 

    printf("in child 2, pid %d ", getpid()); 

    return 0; //子进程结束。跳回父进程

    Printf("hello world");//没有打印

    }

    int st1, st2; 

    waitpid( p1, &st1, 0); 

    waitpid( p2, &st2, 0); 

    printf("in parent, child pid %d ", p1); 

    printf("in parent, child pid %d ", p2); 

    printf("in parent, pid %d ", getpid()); 

    printf("in parent, child exited with %d ", st1); 

    printf("in parent, child exited with %d ", st2); 

    return 0; 

     

     

    另外一种方法: 验证通过 

    特点:同一时候创建两个子进程。结构比較繁琐。程序可读性不好,不易扩展 

     

    #include<stdio.h> 

    #include<unistd.h> 

    #include<sys/types.h> //这个头文件不能少,否则pid_t未定义 

    main() 

    printf("This is parent process%d ",getpid()); 

    pid_t p1,p2; 

    if((p1=fork())==0)

    printf("This is child_1 process%d ",getpid()); 

    }

    Else

    if((p2=fork())==0)

    printf("This is child_2 process%d ",getpid()); 

    }

    Else

    wait(p1,NULL,0); 

    wait(p2,NULL,0); 

    printf("This is parent process%d ",getpid()); 

     

     

    第三种方法:for 循环方法 

    特点:事实上每次循环仅仅是创建了单个进程。并没有同一时候创建多个进程 

    #include<stdio.h> 

    #include<unistd.h> 

    #include<sys/types.h> 

    main() 

    {

    printf("This is parent process%d ",getpid()); 

    pid_t p1,p2; 

    int i; 

    for(i=0;i<=2;i++)

    if((p1=fork())==0)

    printf("This is child_1 process%d ",getpid()); 

    return 0;//这个地方很关键 

    wait(p1,NULL,0); //父进程等待p1子进程运行后才干继续fork其它子进程

    printf("This is parent process%d ",getpid()); 

    }

    注意:标注的 return 对程序结果影响非常大 

     

    无 return 情况 

     

    #include<stdio.h> 

    #include<unistd.h> 

    #include<sys/types.h> 

    main() 

    printf("This is parent process%d ",getpid()); 

    pid_t p1,p2; 

    int i; 

    for(i=0;i<=2;i++)

    if((p1=fork())==0)

    printf("This is child_1 process%d ",getpid()); 

    //return 0;//这个地方很关键 

    wait(p1,NULL,0); 

    printf("This is parent process%d ",getpid()); 

    }

    结论:父进程会生成 n(n+1)/2+1个子进程,为循环次数,本例中共同拥有 个子进程。 但实际上仅仅有 个是父进程产生的。其余都为子进程 fork()出来的。父进程fork3个进程,第一个子进程运行完之后又fork2个进程,第2个子进程fork1个进程。

     

     

     

    正确的使用Linux中的用fork()由一个父进程创建同一时候多个子进程 的格式例如以下:

     

    int status,i;

    for (i 0; 10; i++)

    {

      status fork();

      if (status == || status == -1) break;//每次循环时,假设发现是子进程就直接从创建子进程的循环中跳出来。不让你进入循环,这样就保证了每次仅仅有父进程来做循环创建子进程的工作

    }

    if (status == -1)

    {

      //error

    }

    else if (status == 0) //每一个子进程都会运行的代码

    {

      //sub process

    }

    else

    {

      //parent process

    }

     

  • 相关阅读:
    nginx配置zabbix下setup.php(web页面)无法显示,浏览器无法打开
    CentOS release 6.5下jdk1.7升级到1.8
    tcp流量控制
    图像处理服务器
    muduo rpc protobuf 实现学习
    p2p nat 穿透原理
    博客-livevent-stl-cpp-nginx
    使用eventfd创建一个用于事件通知的文件描述符
    多线程设计的类的思考!
    ftp协议服务器与tinyhttp服务demo
  • 原文地址:https://www.cnblogs.com/yfceshi/p/7066407.html
Copyright © 2011-2022 走看看