多线程和fork


先抛出问题:

如果父进程是多线程进程,那么进行父进程进行fork后,会发生什么?子进程是否也变成多线程进程?


真相是在子进程内部只存在一个线程,它是由父进程中调用fork的线程的副本构成的。


回顾fork编程,子进程会继承整个地址空间的副本,也从父进程那里继承了所有的互斥量、读写锁和条件变量的状态。那么问题来了!

如果父进程包含多个线程,子进程在fork返回后,如果紧接着不是马上调用exec的话,就需要清理锁状态。

为什么需要清理锁状态,如果父进程中的线程占有锁,子进程同样占有这些锁,问题是子进程并不包含占有锁的线程的副本,所以子进程没有办法知道它占有了哪些锁并且需要释放哪些锁。

如果子进程从fork返回以后马上调用某个exec函数,就可以避免这样的问题,这种情况下,老的空间地址被丢弃,所以锁的状态无关要紧。

要清除锁状态,可以通过调用pthread_atfork函数建立fork处理程序


参考:《unix环境高级编程》


End;

你可能感兴趣的:(linux之进程操作,linux,多线程,fork)