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

  • 相关阅读:
    VBA_headers_mapping
    pandas_知识总结_基础
    python_super()及继承顺序
    python_端口扫描
    python_socket登陆验证_明文
    python_sys.argv的使用
    python_os_shutil_获取文件夹下所有文件的大小
    python_面向对象_组合
    魔术球问题 【网络流24题】【建图技巧】
    牛客&科大讯飞杯&SHU、L动物森友会【二分】【网络流】
  • 原文地址:https://www.cnblogs.com/wenming205/p/7561260.html
Copyright © 2011-2022 走看看