我有这段代码并试图了解将从中创建多少进程和线程:
pid t pid;
pid = fork();
if (pid == 0) { /* child process */
fork();
thread create( . . .);
}
fork();
我认为它会创建2个线程,来自if循环中的fork。和8个过程?但我不确定这是否正确
答案 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
因为我用*代表线程。