How many processes are forked here

后端 未结 4 757
不知归路
不知归路 2020-12-22 13:52

I know that it might come as a stupid question but could anyone help me understand the behavior of the following code snippet

//label 0
int main(){
  fork();         


        
相关标签:
4条回答
  • 2020-12-22 14:22

    It's simple there are total 8 process in parallel.

    p ----------------
    |                 |          // first fork() 
    1c-------         p -------   
    |        |        |        |      // second fork()
    2c---    1c---    3c---    p----  
    |   |    |    |   |    |   |    |    // third fork()
    4c  2c   1c   5c  6c  3c   7c   p  
    

    You can count the leaf nodes which is 8 so total 8 processes.

    Explanation : parent p called fork() 2 process 1c first child and parent p.Now the second fork() is for both the processes. so the process 1c,2c,3c,p. So on and you get 8 processes after third fork() call. After fork new process executes just after the code where it is forked. so all the code below the fork is for both parent and the child processes.

    0 讨论(0)
  • 2020-12-22 14:25

    The process tree looks like below. I used following naming convention for processes. prefix parent process name to the corresponding fork label that created it.

                    [0]
              /      |      \
            [01]    [02]    [03]
           /  \       |
        [012] [013] [023]
         /
       [0123]
    

    Like @Mat said, 8 processes are created.

    0 讨论(0)
  • 2020-12-22 14:31

    After the first fork, you have two processes. Both hit the second fork, creating four processes in total.

    All four hit the third fork, so you have eight processes. Then they all exit.

    0 讨论(0)
  • 2020-12-22 14:32

    Yes, the child is a copy of its parent. It inherits execution state too, including where in the code the parent was executing. When the parent returns from the first fork() with the PID (>0) of the child, its first child returns with 0 and then continues on to the second and third forks. The child doesn't go back to the top of main(), it just goes on from after the fork that created it.

    EDIT Re-word in response to comment. See the fork(2) man page for the meaning of all return values.

    0 讨论(0)
提交回复
热议问题