进程间的数据通信与数据共享

本文介绍了Python中进程间通信(IPC)的方式,包括使用multiprocessing模块的队列和管道实现消息传递。同时,探讨了如何通过Manager实现进程间的共享数据,强调了Manager在数据共享以及其他同步原语上的应用。
摘要由CSDN通过智能技术生成

进程彼此之间互相隔离,要实现进程间通信(IPC),multiprocessing模块支持两种形式:队列和管道,这两种方式都是使用消息传递的

进程通信

队列
import multiprocessing

def run(q):
    q.put('hello')
    q.put('mainprocess')
    print('subprocess q ID:',id(q))

if __name__ == '__main__':
    q=multiprocessing.Queue()#用于进程间通信的队列
    t=multiprocessing.Process(target=run,args=(q,))
    t.start()
    t.join()

    print('main process q ID:',id(q))
    print(q.get())
    print(q.get())
'''
subprocess q ID: 2359100652232
main process q ID: 2025858869736
hello
mainprocess
'''
管道
import multiprocessing
def foo(conn):
    data=conn.recv()
    print(data)
    conn.send('subprocess conn id is %s'%(id(conn)))
    print('this is subprocess
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值