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

  • 相关阅读:
    poj1275收银员——差分约束
    poj3565Ants——KM算法
    bzoj2750Road——最短路计数
    poj1236学校网络——连通块
    poj2226Muddy Fields——二分图匹配
    Pots
    蜘蛛牌
    Find The Multiple (水题)
    Dungeon Master (三维bfs)
    棋盘问题 (简单搜索)
  • 原文地址:https://www.cnblogs.com/wenming205/p/7561260.html
Copyright © 2011-2022 走看看