前言
- 多线程中某个线程调用 fork(),子进程会有和父进程相同数量的线程吗?
- 父进程被加锁的互斥锁 fork 后在子进程中是否已经加锁?
先来解决第一个问题:
创建一个线程,有两条路径,一条是主线程,一条是子线程,在主线程加入fork();
fork之后,主进程有两个线程,我们来看看子进程究竟有几个线程
注意:不管在哪个线程打印pid,pid的值都是整个进程的id号
于是:我们发现父进程的pid是5831,子进程的pid是5833,父进程的id在主线程和子线程中均被输出,子进程的id只有在主进程中输出
创建一个线程,有两条路径,一条是主线程,一条是子线程,在子线程执行fork();
执行结果如下:
父进程的id号为5895,子进程的id号为5897
子进程的id号只在子线程打印,父进程的id号在主线程和子线程都打印
总结
- 其实,不管父进程有多少条执行路径,子进程只有一条执行路径;
- 既然父进程有多条执行路径,那么fork执行的就是的fork所在的那一条执行路径中。
fork是复制进程,但是他只会复制进程中的一条执行路径,这是因为设计问题,在设计多线程程序时,最后发现,如果全都复制,程序会非常复杂,难以控制。
对于第二个问题的解答:
父进程中创建了锁,使用它,再fork,其实这个锁是属于父进程的资源,所以子进程也会复制这把锁,就会产生两把锁,锁的状态取决于fork的那一刻父进程锁的状态,子进程会同步于父进程的锁状态。因为程序的并发运行,这个锁的状态难以确定。
我们只能在没有任何控制的时候再进行fork,