Python多进程编程指南

  1. 在Unix上,一个进程结束,如果没有被join,就会变成僵尸进程。但是每一次一个新的进程启动,所有已经完成还没有join的进程都会被join,调用进程的is_alive()方法也会join进程,所以在大多数时候没有显式调用进程的join方法是没有问题的,但是最好显式调用进程对象的join方法。

  2. 在一个进程中put
    item到queue中,这个进程在终止之前会一直等待直到queue中的item被消费掉。这意味着要确保在队列中的item被完全消费掉之后再调用进程的join方法,否则可能会导致死锁。

    
    def f(q):
        q.put('X' * 1000000)
    
    if __name__ == '__main__':
        queue = Queue()
        p = Process(target=f, args=(queue,))
        p.start()
        p.join()                    # 这里导致死锁 因为进程先join了
        obj = queue.get() ```
    
  3. 在Unix上,子进程可以使用父进程创建的全局对象作为共享资源来使用,但是最好把共享资源作为参数传递给子进程的构造函数,这样除了和Windows上的代码兼容,还可以防止资源在父进程中被垃圾回收了。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值