python multiprocessing join_python – 为什么没有join()的守护程序退出

答案可能就在我面前的链接上,但我仍然不明白.我确定在有人向我解释之后,达尔文会打电话给我.

这个例子是at this link here,虽然我做了一些改变,试图尝试并帮助我理解.

这是代码:

import multiprocessing

import time

import sys

def daemon():

p = multiprocessing.current_process()

print 'Starting: ', p.name, p.pid

sys.stdout.flush()

time.sleep(2)

print 'Exiting: ', p.name, p.pid

sys.stdout.flush()

def non_daemon():

p = multiprocessing.current_process()

print 'Starting: ', p.name, p.pid

sys.stdout.flush()

time.sleep(6)

print 'Exiting: ', p.name, p.pid

sys.stdout.flush()

if __name__ == '__main__':

d = multiprocessing.Process(name='daemon', target=daemon)

d.daemon = True

n = multiprocessing.Process(name='non-daemon', target=non_daemon)

n.daemon = False

d.start()

time.sleep(1)

n.start()

# d.join()

并且代码的输出是:

Starting: daemon 6173

Starting: non-daemon 6174

Exiting: non-daemon 6174

如果取消注释末尾的join(),则输出为:

Starting: daemon 6247

Starting: non-daemon 6248

Exiting: daemon 6247

Exiting: non-daemon 6248

我很困惑b / c守护进程的睡眠是2秒,而非守护进程是6秒.为什么不在第一种情况下打印出“退出”消息?守护进程应该在非守护进程之前唤醒并打印消息.

该网站的解释如下:

The output does not include the “Exiting” message from the daemon

process, since all of the non-daemon processes (including the main

program) exit before the daemon process wakes up from its 2 second

sleep.

但我改变了它,以至于守护进程应该在非守护进程之前唤醒.我在这里错过了什么?在此先感谢您的帮助.

编辑:忘了提到我正在使用python 2.7但显然这个问题也在python 3.x中

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值