将创建多少个进程和线程?

时间:2013-03-08 18:28:56

标签: multithreading fork pid

我有这段代码并试图了解将从中创建多少进程和线程:

pid t pid; 
pid = fork(); 
if (pid == 0) { /* child process */ 
 fork(); 
 thread create( . . .); 
} 
fork(); 

我认为它会创建2个线程,来自if循环中的fork。和8个过程?但我不确定这是否正确

3 个答案:

答案 0 :(得分:12)

实际上,应该有8个线程和6个进程。

这是清楚的图表:

1) after first fork():

   |-------------------  child of p0 [p1]
---|-------------------  parent      [p0]

2) after second fork():

       |---------------  child of p1 [p2]
   |---|---------------              [p1]
---|-------------------              [p0]

3) after pthread_create():

            -----------  thread 1 of p2 [p2t1] 
       |---/-----------  thread 0 of p2 [p2t0]
       |    -----------  thread 1 of p1 [p1t1]
   |---|---/-----------  thread 0 of p1 [p1t0]
---|-------------------                 [p0]

4) after third fork():

         |------------ child of p2 [p5]
         |      ------             [p2t1]
       |-|-----/------             [p2t0]
       |   |---------- child of p1 [p4]
       |   |    ------             [p1t1]
   |---|---|---/------             [p1t0]
   |     |------------ child of p0 [p3]
---|-----|------------             [p0]

重要:请记住,fork(2)调用克隆只是执行它的线程,因此进程4 [p4]只有一个线程(同样适用于进程5 [p5])。

答案 1 :(得分:8)

每次调用fork时都会创建一个额外的进程。

首次调用fork时,父进程P创建子进程SP1。 fork之后,父进程再次调用fork(跳过if),创建子进程SP2。

fork内的fork调用if之后的

SP1,创建子子进程SSP1。 SP1然后生成一个线程。 SP1离开if。并再次调用fork,创建子子流程SSP2。

SSP1产生一个线程。 SSP1离开if,并调用fork,创建子子进程SSSP。

因此,创建的进程:SP1,SP2,SSP1,SSP2,SSSP = 5进程。 如果计算原始流程P,则有6个流程。

只有SP1和SSP1产生线程,因此创建了2个线程。如果计算所有进程的所有主线程,则有7个或8个线程,具体取决于您是否计算原始进程P.

与代码相关的正在创建的进程和线程的说明。

                         P
pid t pid;               |
pid = fork();            +------SP1
if (pid == 0) {          |      |
 fork();                 |      +---------------SSP1
 thread create(...);     |      |-SP1's thread  |-SSP1's thread
}                        |      |               |
fork();                  +-SP2  +-SSP2          +-SSSP
                         | |    | |             | |

答案 2 :(得分:0)

不应该是2个线程和6个进程吗?

M
|  ↘
M     A
|     |↘
M     A*   B*
|     |    |
| ↘   | ↘  |↘
M   C A  D B  E

因为我用*代表线程。