Linux中fork()函数详解 父子进程变量的关系

您所在的位置:网站首页 定义变量有哪些内容组成的函数 Linux中fork()函数详解 父子进程变量的关系

Linux中fork()函数详解 父子进程变量的关系

2024-07-13 04:30| 来源: 网络整理| 查看: 265

一、fork入门知识

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

     我们来看一个例子:

[cpp]  view plain copy /*   *  fork_test.c   *  version 1   *  Created on: 2010-5-29   *      Author: wangth   */   #include    #include     int main ()    {        pid_t fpid; //fpid表示fork函数返回的值       int count=0;       fpid=fork();        if (fpid p3225(当前进程)->p3227(被创建的子进程)。从输出可以看到p3225原来是p3224的子进程,现在变成p3227的父进程。父子是相对的,这个大家应该容易理解。只要当前进程执行了fork,该进程就变成了父进程了,就打印出了parent。     所以打印出结果是:     1 parent 2043 3224 3226     1 parent 3224 3225 3227      第三步:第二步创建了两个进程p3226,p3227,这两个进程执行完printf函数后就结束了,因为这两个进程无法进入第三次循环,无法fork,该执行return 0;了,其他进程也是如此。     以下是p3226,p3227打印出的结果:     1 child     1 3227    0     1 child     1 3226    0      细心的读者可能注意到p3226,p3227的父进程难道不该是p3224和p3225吗,怎么会是1呢?这里得讲到进程的创建和死亡的过程,在p3224和p3225执行完第二个循环后,main函数就该退出了,也即进程该死亡了,因为它已经做完所有事情了。p3224和p3225死亡后,p3226,p3227就没有父进程了,这在操作系统是不被允许的,所以p3226,p3227的父进程就被置为p1了,p1是永远不会死亡的,至于为什么,这里先不介绍,留到“三、fork高阶知识”讲。     总结一下,这个程序执行的流程如下:

     这个程序最终产生了3个子进程,执行过6次printf()函数。     我们再来看一份代码:

[cpp]  view plain copy /*   *  fork_test.c   *  version 3   *  Created on: 2010-5-29   *      Author: wangth   */   #include    #include    int main(void)   {      int i=0;      for(i=0;i


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3