创新互联Python教程:python进程之间如何通信

本文教程操作环境:windows7系统、Python 3.9.1,DELL G3电脑。

成都创新互联主营新宾网站建设的网络公司,主营网站建设方案,成都App定制开发,新宾h5微信小程序开发搭建,新宾网站营销推广欢迎新宾等地区企业咨询

1、思路

Process之间肯定是需要通信的,操作系统提供了很多机制来实现进程间的通信。Python的multiprocessing模块包装了底层的机制,提供了Queue、Pipes等多种方式来交换数据。

2、实例

以Queue为例,在父进程中创建两个子进程,一个往Queue里写数据,一个从Queue里读数据。

from multiprocessing import Process, Queue
import os, time, random
 
# 写数据进程执行的代码:
def write(q):
    print('Process to write: %s' % os.getpid())
    for value in ['A', 'B', 'C']:
        print('Put %s to queue...' % value)
        q.put(value)
        time.sleep(random.random())
 
# 读数据进程执行的代码:
def read(q):
    print('Process to read: %s' % os.getpid())
    while True:
        value = q.get(True)
        print('Get %s from queue.' % value)
 
if __name__=='__main__':
    # 父进程创建Queue,并传给各个子进程:
    q = Queue()
    pw = Process(target=write, args=(q,))
    pr = Process(target=read, args=(q,))
    # 启动子进程pw,写入:
    pw.start()
    # 启动子进程pr,读取:
    pr.start()
    # 等待pw结束:
    pw.join()
    # pr进程里是死循环,无法等待其结束,只能强行终止:
    pr.terminate()

以上就是python进程之间通信的方法,希望能对大家有所帮助。更多Python学习指路:创新互联Python教程

分享文章:创新互联Python教程:python进程之间如何通信
URL分享:http://www.shufengxianlan.com/qtweb/news34/66584.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联