线程和fork-

关键接口:

  • 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 高级环境编程》中提到的:当父进程和子进程对他们的锁副本解锁时,父进程的内存复制到子进程中,这话的意思是: 复制好内存后,再解锁还是解锁时才复制?????

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值