zoukankan      html  css  js  c++  java
  • c语言fork 多进程


    fork函数的作用

    一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
    一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己。

    fork出错可能有两种原因
    1)当前的进程数已经达到了系统规定的上限,这时errno的值被设置为EAGAIN。
    2)系统内存不足,这时errno的值被设置为ENOMEM。
    创建新进程成功后,系统中出现两个基本完全相同的进程,这两个进程执行没有固定的先后顺序,哪个进程先执行要看系统的进程调度策略。

    root@localhost:~# vi fork_test.c
    #include <unistd.h>
    #include <stdio.h>
    
    int main()
    {
            pid_t fpid;
            int count = 0 ;
    
            printf("start 
    ");
    
            fpid = fork();
    
            printf("fork 
    ");
    
            if(fpid<0)
            {
                    printf("error in fork! 
    ");
            }
            else if (fpid==0)
            {
                    printf("child process %d 
    ",getpid());
                    count ++;
            }
            else
            {
                    printf("parent process %d 
    ",getpid());
                    count ++;
            }
            printf("统计结果是:%d 
    ",count);
            return 0 ;
    }
    root@localhost:~# gcc fork_test.c  -o fork_test
    root@localhost:~# ./fork_test 

    输出结果如下:

    start 
    fork 
    parent process 1579 
    统计结果是:1 
    root@localhost:~# fork 
    child process 1580 
    统计结果是:1

    总结: fork函数 会创建一个新进程,pid为0时是子进程 ,pid 不为零时是父进程。 

    子进程执行是从fork开始执行的。fork之前的,不用再次执行。

    参考文档:http://www.cnblogs.com/jeakon/archive/2012/05/26/2816828.html

  • 相关阅读:
    Android 逐帧动画
    MAP getLastKnownLocation()返回null的解决
    大数取余
    (a^b)%c和(a/b)%c
    HDU1046 Gridland
    顺序入栈的出栈方法种数
    HDU1021 Fibonacci Again
    HDU1019 Least Common Multiple
    HDU1018 Big Number
    HDU1013 Digital Roots
  • 原文地址:https://www.cnblogs.com/wenming205/p/7561260.html
Copyright © 2011-2022 走看看