关键接口:
pthread_atfork(void (*prepare)(void),void (*parent)(void), void(*child)(void))
pthread_atfork: 最先调用.
prepare: 在父进程fork创建子进程之前调用,获取父进程定义的所有锁;
child: fork返回之前,在子进程环境中调用,在这里unlock prepare 获得的锁;
parent: fork创建了子进程以后,在fork返回之前在父进程的进程环境中调用,对prepare获得的锁进行解锁;多线程fork()之后容易出现死锁案例:
参考: http://www.cnblogs.com/peimin/p/3526357.html
http://blog.csdn.net/y396397735/article/details/51085583
操作:
一个多线程进程的某个线程调用了fork函数,子进程只拥有一个执行线程,并且完整复制该线程以及自动继承父进程中互斥锁的状态 .
引来问题: 父进程的线程占有锁,子进程将同样占有.(从父进程复制了锁的状态,却不知道锁状态)
子进程可能不清楚从父进程中继承来的互斥锁的具体状态(加锁或者解锁状态未知)。
若互斥锁加锁了,并且由创建fork外的其他线程锁住。此种情况,子进程若再次对该互斥锁执行加锁操作会导致死锁。
解决:
1、if 调用exec : 旧地址空间被丢弃. (这种方式限制了子进程能做什么)
2、else 调用pthread_atfork进行清锁处理.问题: 关于加锁一次解锁两次的问题:
在《unix 高级环境编程》中提到的:当父进程和子进程对他们的锁副本解锁时,父进程的内存复制到子进程中,这话的意思是: 复制好内存后,再解锁还是解锁时才复制?????