Python并发编程-管道

Posted 空林~~清风~~~

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python并发编程-管道相关的知识,希望对你有一定的参考价值。

管道的作用- 两个进程间传递消息

from multiprocessing import Pipe, Process

def func(conn1,conn2):
    conn2.close() #子进程只需使用connection1,故关闭connection2
    while True:
        try:
            msg = conn1.recv()
            print(msg)
        except EOFError:  #没收数据接收的时候,才抛出的异常
            conn1.close()
            break

if __name__ == '__main__':
    conn1,conn2 = Pipe()#建立一个管道,管道返回两个connection
    Process(target=func, args=(conn1,conn2)).start()
    conn1.close() #主进程只需要一个connection,故关闭一个
    for i in range(20):
        conn2.send('吃了吗') #主进程发送
    conn2.close() #主进程关闭connection2

以上是关于Python并发编程-管道的主要内容,如果未能解决你的问题,请参考以下文章

Python并发编程—进程间通信

python并发编程(管道,事件,信号量,进程池)

python并发编程:多进程-队列

Python 3 并发编程多进程之队列(推荐使用)

[Go] 通过 17 个简短代码片段,切底弄懂 channel 基础

Python - 并发编程