python多进程的主进程阻塞,使用管道的Python多进程非阻塞互通

Is it possible to receive process intercommunications using Pipes in a non-blocking fashion?

Consider the following code:

from multiprocessing import Process, Pipe

import time

def f(conn):

time.sleep(3)

conn.send('Done')

conn.close()

if __name__ == '__main__':

parent_conn, child_conn = Pipe()

p = Process(target=f, args=(child_conn,))

p.start()

while True:

print('Test')

msg = parent_conn.recv()

if msg == 'Done':

break

print('The End')

p.join()

The parent_conn.recv() will block the while-loop until a message is received. Is there a way to listen for messages in a non-blocking way?

解决方案

Use the poll function. Change your while loop like this:

while True:

print('Test')

if parent_conn.poll():

msg = parent_conn.recv()

if msg == 'Done':

break

else:

do_something_else()

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值