首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >无法在大队列多处理上使用join -Python

无法在大队列多处理上使用join -Python
EN

Stack Overflow用户
提问于 2018-07-02 19:27:14
回答 1查看 185关注 0票数 0
代码语言:javascript
运行
复制
#Each pic's size is 1280x720 
import time

from multiprocessing import Process,JoinableQueue,Queue,Value

**def create_row(M, q_row,y_val):**    #creating lines. len:720 len of each     

    line_len=720
    col_len=1280

    for i in range(line_len):
       q_row.put(M[(i*col_len):((i+1)*col_len)])


**def create_col(M, q_col,x_val):** #creating cols

    col_len=1280  
    line_len=720

    for i in range(col_len): 
        l = list() 
        for j in range(line_len):
            l.append(M[j*line_len + i])    
        q_col.put(l)

**def main():**

    #creating row and col Queue
    q_row=JoinableQueue()
    q_col=JoinableQueue()

    x_val=Value('i',-1)
    y_val=Value('i',-1)

    p1=Process(target=create_row,args=(M,q_row,y_val))
    p2=Process(target=create_col,args=(M,q_col,x_val))
    q_row.join()
    q_col.join()
    p1.start()
    p2.start()
    p1.join()
    p2.join()

现在来看问题:

M是大小为1280×720的列表,其表示一幅图片。

我们希望将列表划分为行和列,这样我们就可以更快地浏览整个图片。

我们尝试了以下几种方法:

  1. Without加入进程:在这种情况下,只有一个函数可以工作(我们将只获得加入进程的row_q或col_q)
  2. With::程序将冻结。

我该怎么办?

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51135131

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档