python 关闭子进程_python-即使子进程已关闭,MultiProcessing Pipe re...

阅读有关此主题的几个问题后,我现在知道子进程从父进程继承了文件描述符.当父母关闭连接时,这会使孩子更难收到EOFError.

但是我的情况恰恰相反,我不明白我面临的问题.

我有一个父进程,该进程启动一个子进程,并使其能够访问我创建的Pipe连接的一端.现在,当子进程完成,出现故障或其他任何情况时,所有操作都将停止并关闭连接.此时,子进程显示为已失效.

然后,我希望父进程的连接在阻塞的recv调用上抛出EOFError.但是相反,它只是坐在那里等待.

我在这里想念什么?

编辑

我认为这个例子代表了问题:

from multiprocessing import Process, Pipe

from threading import Thread

import time

class Parent(object):

def __init__(self):

self.parent_conn, child_conn = Pipe()

self.child = Process(target=Child, args=(child_conn,))

self.child.start()

def recv():

try:

self.parent_conn.recv()

except EOFError:

print "EOF"

except:

print "something else"

# Does not work

recv()

# Works fine

t = Thread(target=recv)

t.setDaemon(True)

t.start()

def close(self):

self.parent_conn.close()

self.child.join()

class Child(object):

def __init__(self, conn):

conn.close()

if __name__ == "__main__":

p = Parent()

time.sleep(1)

p.close()

如果我确实使用单独的线程,则允许父级关闭其自己的连接,并且一切正常. (请注意,您仍然需要知道子进程的完成方式,才能做到这一点.)相反,如果我直接调用recv,它将明显阻塞,但是我怀疑一旦子进程关闭其连接,它将引发EOFError.但事实并非如此.谁能澄清?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值