8、多进程之间的通信

news2025/1/17 0:01:44

多进程之间的常用通信方法有两种,及Queue和Pipe
一、Queue
Queue([maxsize]):创建共享的进程队列。maxsize是队列中允许的最大项数。如果省略此参数,则无大小限制。底层队列使用管道和锁定实现。另外,还需要运行支持线程以便队列中的数据传输到底层管道中。
Queue的实例q具有以下方法:

q.get( [ block [ ,timeout ] ] ):返回q中的一个项目。如果q为空,此方法将阻塞,直到队列中有项目可用为止。block用于控制阻塞行为,默认为True. 如果设置为False,将引发Queue.Empty异常(定义在Queue模块中)。timeout是可选超时时间,用在阻塞模式中。如果在制定的时间间隔内没有项目变为可用,将引发Queue.Empty异常。

q.get_nowait() :同q.get(False)方法。

q.put(item [, block [,timeout ] ] ) :将item放入队列。如果队列已满,此方法将阻塞至有空间可用为止。block控制阻塞行为,默认为True。如果设置为False,将引发Queue.Empty异常(定义在Queue库模块中)。timeout指定在阻塞模式中等待可用空间的时间长短。超时后将引发Queue.Full异常。

q.qsize() :返回队列中目前项目的正确数量。此函数的结果并不可靠,因为在返回结果和在稍后程序中使用结果之间,队列中可能添加或删除了项目。在某些系统上,此方法可能引发NotImplementedError异常。

q.empty() :如果调用此方法时 q为空,返回True。如果其他进程或线程正在往队列中添加项目,结果是不可靠的。也就是说,在返回和使用结果之间,队列中可能已经加入新的项目。

q.full() :如果q已满,返回为True. 由于线程的存在,结果也可能是不可靠的(参考q.empty()方法)。
在这里插入图片描述
就比如,进程1所得到的结果,要在进程2、3、4等进程当中用,此时,可以通过Queue,让其他进程来获得进程1中的结果。
现在,我们有一个场景,在一个进程当中,计算出两个数的和,然后在另外一个进程中使用第一个进程中计算的结果,除以2,即得到这两个数的平均值,代码如下:

from multiprocessing import Process,Queue
class AddProc(Process):
    def __init__(self,q,number1,number2):
        super(AddProc, self).__init__()
        self.number1 = number1
        self.number2 = number2
        self.q=q
    def run(self):

        res = self.number1 + self.number2
        self.q.put(res)
        print("相加进程1:",res)
class DiviSion(Process):
    def __init__(self,q):
        super(DiviSion, self).__init__()
        self.q = q
    def run(self):
        res = self.q.get()/2
        print("除2进程2:",res)

if __name__ == '__main__':
    print("主进程开始")
    q = Queue()
    p1 = AddProc(q,12,13)
    p2 = DiviSion(q)
    p1.start()
    p2.start()
    p1.join()
    p2.join()
    print("主进程结束!")

二、Pipe
在这里插入图片描述

管道通信,就是各个进程之间相互通信,有双工和半双工两种方式,默认为双工通信

同样,拿上面的案例,改用管道通信改写,就变成下面这个样子:

from multiprocessing import Process,Pipe
class AddProc(Process):
    def __init__(self,pi1,number1,number2):
        super(AddProc, self).__init__()
        self.number1 = number1
        self.number2 = number2
        self.pi1=pi1
    def run(self):

        res = self.number1 + self.number2
        self.pi1.send(res)
        print("相加进程1:",res)


class DiviSion(Process):
    def __init__(self,pi2):
        super(DiviSion, self).__init__()
        self.pi2 = pi2
    def run(self):
        res = self.pi2.recv()/2
        print("除2进程2:",res)
if __name__ == '__main__':
    pi1,pi2=Pipe()
    print("主进程开始")
    p1 = AddProc(pi1,12,13)
    p2 = DiviSion(pi2)
    p1.start()
    p2.start()
    p1.join()
    p2.join()
    print("主进程结束!")

p1,p2=Pipe():Pipe创建之后得到管道的两端
self.pi1.send() :write进程负责把数据通过管道发送给另一个进程
self.pi2.recv():当管道中没有数据,该行代码一直阻塞
recv函数是阻塞函数

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/48416.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Docker网络模式之bridge-尚文网络xUP楠哥

~~全文共1572字,阅读需约5分钟。 进Q群11372462,领取专属报名福利,包含云计算学习路线图代表性实战训练大厂云计算面试题资料! 当docker已经启动后,会生成一个名字叫做docker0的虚拟网桥,给到一个默认的IP地址为172.1…

Databend 开源周报 #69

Databend 是一款强大的云数仓。专为弹性和高效设计,自由且开源。 即刻体验云服务:https://app.databend.com。 New Features multiple catalog 实现删除用户定义目录 (#8820) meta 新增用于删除 key 和使 key 过期的 cli 命令 (#8858) planner 支…

30组易混易错词汇辨析,柯桥成人英语培训哪家好

30组易混易错词汇辨析 1. clothes, cloth, clothing clothes统指各种衣服,谓语动词永远是复数, cloth指布,为不可数名词 clothing 服装的总称,指一件衣服用a piece of, an article of 2. amount, number amount后接不可数名词…

求Huffman树的带权路径长度

Huffman树的建立过程: 首先得到整个叶子结点的集合: 求Huffman树的带权路径长度算法: 书上讲常见的求Huffman树的带权路径长度算法为:从叶子结点权值乘路径长度: WPL7*25*25*23*32*349 另外一种求WPL的算法为&…

视频编解码学习之一:理论基础

1. 为什么要进行视频压缩? 未经压缩的数字视频的数据量巨大 存储困难 一张DVD只能存储几秒钟的未压缩数字视频。 传输困难 1兆的带宽传输一秒的数字电视视频需要大约4分钟。 \2. 为什么可以压缩 去除冗余信息 空间冗余:图像相邻像素之间有较强的相关性…

化工厂人员定位系统:以安全为出发点,助力企业安全生产管控数智化

化工厂人员定位系统采用先进的高精度时间同步技术和调度技术,可在复杂化工场景中精准锁定作业人员在多层空间内的实时位置,实现高精度人员定位。 如何管理好每个车间的作业人员? 如何监管作业人员是否按时到岗? 如何知晓当前人员…

阿里专家精心整理分享的Java程序员面试笔试通关宝典PDF

前言 学习是一种基础性的能力。然而,“吾生也有涯,而知也无涯。”,如果学习不注意方法,则会“以有涯随无涯,殆矣”。 学习就像吃饭睡觉一样,是人的一种本能,人人都有学习的能力。我们在刚出生…

MuLogin的WebRTC功能介绍与设置

WebRTC 协议可以绕过代理取到一些本机的网卡IP和真实的上网公网IP地址,那么我们可以使用替换模式来让网站取到我们指定的IP信息,或用禁用模式,让被访问的网站不能通过WebRTC协议来取我们的IP地址。这里如果你不知道公网IP是多少,建…

18.JVM

目录 1.编写源代码 2.JDK (Java Development Kit) 3.JRE(Java Runtime Environment) Java运行时环境 4.JVM 1.类名 2.类文件放在哪? 13JVM按需加载类,那么何时加载一个类? 4.类文件是怎么来的? 5…

WebRTC学习笔记五 SDP(Session Description Protocol)

SDP里面内容虽然很多,但是条理很清楚。SDP值为字符串,通过换行符生成一行一行的SDP报文,所有行可分为三类:全局行、音频行、视频行 v - Version,版本,版本,应等于0 o - Origin,源&a…

Github优秀项目-使用Python基于GPT2文本自动生成

基于 GPT2-Chinese 模型的中文文本生成项目,可用于中文生成任务。 当下市面上很多文本自动生成业务都是基于该模型二次开发的,可以很少有那种特定垂直领域的模型用于该领域的创作,也就导致大家在使用类似产品的时候会发现很多的问题,这种问题多数会导致写出来的文章前后逻…

工业大数据收集及预测建模方法(南京大学-宋哲博士分享)- 个人总结

获取工业大数据途径 Retrospective Study(回溯性研究):完全依赖于现有的历史数据,去数据挖掘、学习和建模;Observational Study(观察性研究):在一段时间内观察要研究的工业过程,微调相关的控制参数,看系统…

闲人闲谈PS之三十五——物资备货与提前采购

惯例闲话:又一年快过去了,回想刚刚开始在CSDN上写笔记,还是2年前的事情。闲人其实是一个拖延症十分严重的人,自从开始走上写作这条路之后,治疗拖延症找到了办法,每天总有一些事情让闲人去思考,然…

Banana Pi开源社区开源硬件瑞芯微RK3568/RK3588全国产化支持计划

随着国产芯片的崛起与电子供应链的国产化率越来越高,全国产替换从技术上成为了可能。加上近几年地缘政治的影响,全国产替换的呼声越来越高,已经提升到了国家战略层面。国产替换成为了一股技术前进的力量。 Banana Pi开源社区,全力…

操作系统_多线程笔记(二)

文章目录1.线程状态2.多线程在的意义是什么?1.线程状态 状态是针对当前线程调度的情况来描述的,因为线程是系统调度的基本单位,所以状态是属于线程的属性 线程的六种状态: 注意: 1.一旦内核里的PCB消亡了,此时代码中创建的thread也就没有用了,即内核里的线程释放的时候无…

终于有阿里p9架构师分享出困扰我多年的分布式系统开发实战文档

前言 都说程序员工资高、待遇好, 2022 金九银十到了,你的小目标是 30K、40K,还是 16薪的 20K?作为一名 Java 开发工程师,当能力可以满足公司业务需求时,拿到超预期的 Offer 并不算难。然而,提升…

ANR 触发、监控、分析 一网打尽

平时看博客或者学知识,学到的东西比较零散,没有独立的知识模块概念,而且学了之后很容易忘。于是我建立了一个自己的笔记仓库 (一个我长期维护的笔记仓库,感兴趣的可以点个star~你的star是我写作的巨大大大大的动力),将…

用VS软件开发“浪漫烟花“<笔记摘录>

此处主要讲:如何开发一个连续的烟花弹上升并进行烟花爆炸的程序. 第一步自然是创建窗口,设置窗口宽度为1200,高度为800(#include <graphics.h>) initgraph(1200, 800);//创建窗口,宽度1200,高度800 第二步我们需要为这个窗口添加背景音乐,这里我们添加了一首"周杰伦…

【使用 BERT 的问答系统】第 1 章 : 自然语言处理简介

&#x1f50e;大家好&#xff0c;我是Sonhhxg_柒&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流&#x1f50e; &#x1f4dd;个人主页&#xff0d;Sonhhxg_柒的博客_CSDN博客 &#x1f4c3; &#x1f381;欢迎各位→点赞…

【车间调度】基于模拟退火优化算法的的并行车间机器优化调度(Matlab代码实现)

目录 1 概述 2并行机调度问题的的描述 3 模拟退火法 4 基于模拟退火优化算法的的并行车间机器优化调度&#xff08;Matlab代码实现&#xff09; 4.1 运行结果 5 参考文献 6 Matlab代码 1 概述 并行机调度&#xff08;也称并行多机调度, Parallel MachinesScheduling Prob…