python主进程 子进程_Python在主进程被终止时终止所有子进程

主进程使用多处理过程(). 子进程还创建了自己的子进程。下面是示例代码:import multiprocessing

class MyClass(object):

def __init__(self, name):

self.name = name

def print_info(self):

proc_name = multiprocessing.current_process().name

print 'Consumer %s has producer %s' % (proc_name, self.name)

def consumer(q):

task = q.get()

task.print_info()

def producer():

queue = multiprocessing.Queue()

proc_name = multiprocessing.current_process().name

p = multiprocessing.Process(target=consumer, args=(queue,))

child_proc_name = p.name

print 'Producer %s has consumer %s' % (proc_name, child_proc_name)

p.start()

queue.put(MyClass(name=proc_name))

queue.close()

queue.join_thread()

p.join()

if __name__ == '__main__':

procs = []

for _ in range(5):

p = multiprocessing.Process(target=producer, args=())

p.start()

procs.append(p)

for p in procs:

p.join()

我的问题主要是在程序退出时出现问题时如何清理所有进程。问题可能是进程被信号终止,或者某些子进程得到异常。我基本上想清理所有进程,如果有任何进程因问题而终止。我用的是python2.7。在

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值