python multiprocess queue_Python:Multiprocessing Queue.put不适用于半大数...

啊,我现在知道了问题所在.

from Queue import Queue

from multiprocessing import Queue

不在同一队列中.多处理(mp)队列中包含一些特殊的代码,以允许它在进程之间来回传递值.这是python GIL和线程障碍的结果.

What is happening, is the queue will not allow the process it is in to die until it is empty.请特别注意第二个红色突出显示的警告.循环正常结束,队列不允许终止python进程,因为队列不在共享内存中,就像您期望的那样.我对mp.Queue背后的过程并不完全熟悉,但是它涉及在放置和获取过程之间腌制队列中的项目.因此,异常地消除一个过程可能会导致死锁.

因此,您需要使用queue.get()完全卸载队列,然后进程将按预期终止.

该代码将按照您的预期终止:

from multiprocessing import Process,Queue

if __name__ == "__main__":

tobeQueue = Queue()

for i in range(1,10000):

tobeQueue.put(i)

for i in range(1,10000):

tobeQueue.get() #remove all 9999 items, allow it to die.

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值