doutangliang7769 2018-12-22 06:30
浏览 670
已采纳

为什么Python的multiprocessing.Queue不会阻塞

I am new to Python, but I want to write a multiproccesing program that uses multiprocessing.Queue as Go's channel. However, it seems that multiprocessing.Queue.put(, block=True) doesn't block as documented.

Here is my Python example program:

import multiprocessing
import select
import time


def f(q):
    while True:
        time.sleep(1)
        print("Put")
        q.put("hello world")


if __name__ == "__main__":
    q = multiprocessing.Queue(maxsize=0)
    f(q)

I expect that it will print only one "Put" and blocks forever. However, what I got is that it prints "Put" repeatedly.

Here is the Go program I think almost equivalent, except that goroutine is a green thread but not a process.

package main

import (
    "fmt"
    "time"
)

func main() {
    ch := make(chan int)
    for {
        time.Sleep(time.Second)
        fmt.Println("Put")
        ch <- 1
    }
}

When I type go run csp.go, it prints only one "Put" and the Go runtime prompts that the program is in deadlock.

Why multiprocessing.Queue.put() doesn't block?

  • 写回答

1条回答

  • duansha7453 2018-12-22 06:42
    关注

    Give a queue length of 1 and it will block as required

       Python 2.7.12 (default, Nov 12 2018, 14:36:49) 
        [GCC 5.4.0 20160609] on linux2
        Type "help", "copyright", "credits" or "license" for more information.
        >>> import multiprocessing
        >>> import select
        >>> import time
        >>> 
        >>> q = multiprocessing.Queue(maxsize=1)
        >>> q.put(9)
        >>> q.put(10)  // blocking here, have to ctrl-c to escape
        ^CTraceback (most recent call last):
          File "<stdin>", line 1, in <module>
          File "/usr/lib/python2.7/multiprocessing/queues.py", line 101, in put
            if not self._sem.acquire(block, timeout):
        KeyboardInterrupt
        >>> 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站