Python 从入门到实战37(进程间通信)

我们的目标是:通过这一套资料学习下来,可以熟练掌握python基础,然后结合经典实例、实践相结合,使我们完全掌握python,并做到独立完成项目开发的能力。

上篇文章我们讨论了通过multiprocessing模块创建进程操作的相关知识。今天学习一下进程间通信方式。

1、进程间能否直接共享信息

上一节我们学会了创建多个子进程,每个进程之间有什么关系呢?每个进程都有自己的地址空间、内存、数据栈以及其它记录其运行状态的辅助数据。我们举例说明进程之间能否之间共享信息:

定义一个全局变量,创建两个子进程对全局变量执行不同的操作。输出操作后的结果,查看:

#定义一个全局变量glo_num,创建两个子进程对全局变量执行不同的操作。输出操作后的结果
def plus():
    print("************子进程1开始************")
    global glo_num
    glo_num = 200+100
    print("glo_num is %d"%glo_num)
    print("************子进程1结束************")

def minus():
    print("************子进程2开始************")
    global glo_num
    glo_num = 200-100
    print("glo_num is %d"%glo_num)
    print("************子进程2结束************")

glo_num = 200
def main():
    print("************主进程开始************")
    print("父进程 的PID :%s。"%os.getpid())
    p1 = Process(target=plus)  #实例化进程1
    p2 = Process(target=minus) #实例化进程2
    p1.start()  #开启进程1
    p2.start()
    p1.join()   #等待p1进程结束
    p2.join()
    print("************主进程结束************")

if __name__=="__main__":
    main()

输出结果参考:

我们可以看到全局变量200作为两个进程的初始值进行计算的。子进程之间没有共享信息。

如是修改:plus后面增加括号后,查看结果,进程就共享了信息。

p1 = Process(target=plus())  #实例化进程1,增加括号后
p2 = Process(target=minus()) #实例化进程2

2、多进程队列的使用

在Python中,队列是一种线性数据结构,遵循先进先出(FIFO)原则。Python的标准库中提供了queue模块,其中Queue类可以用来创建线程安全的队列。进程间就可以使用Queue来实现数据的传递

Queue常用的方法:

1)q=Queue(num)   :初始化Queue()对象,num为指定的最大可接收消息数量,若num为空或者负数时,就代表可接收的消息数量没有上限,直到内存的尽头

2)Queue.qsize():返回当前队列包含的消息数量;

3)Queue.empty(): 如果队列为空,返回True ;否则返回False

4) Queue.full():如果队列满了,返回True ;否则返回False;

5)Queue.get([block[,timeout]):获取队列中的一条消息,然后将其从队列中移除,block默认为True;如果block 使用默认值,且没有设置timeout(单位:s)消息队列为空,则此时程序会被阻塞。直到从消息读到消息位置,若设置了timeout,则会等待timeout 秒,若是还是没有任何消息,则抛出Queue.empty异常

如果block 使用False,消息队列为空,会立即抛出Queue.empty异常;

  1. Queue.get_nowait():相当于Queue.get(False);
  2. Queue.put([block[,timeout]):将item消息写入队列中,block默认为True;如果block 使用默认值,且没有设置timeout(单位:s),消息队列中已没有空间可写入,则此时程序会被阻塞。直到从空间可以写入消息为止,若设置了timeout,则会等待timeout 秒,若是还是没有任何写入空间,则抛出Queue.Full异常

如果block 使用False,消息队列没有空间可写入,会立即抛出Queue.Full异常;

  1. Queue.put_nowait(item):相当于Queue.put(item,False)

参考代码如下:

from multiprocessing import Queue
def main():
    q = Queue(3)    #初始化Queue 对象,最多可接收3条信息
    q.put("message 1")
    q.put("message 2")
    print("队列还有空间吗?",q.full())  #队列是否满,返回False

    q.put("message 3")
    print("队列还有空间吗?", q.full()) #队列是否满,返回True
    #尝试继续放入消息,如是没有空间写入,延时2秒后报错
    try:
        q.put("message",True,2)
    except:
        print("消息队列已满,现有消息数量:%s"%q.qsize())

    #读取消息时,先判断消息队列是否为空
    if not q.empty():
        print("队列中消息为非空,读取消息")
        for i in range(q.qsize()):
            print(q.get_nowait())   #读取消息,无消息时报错不等待
    #写入队列消息,先判断是否已满
    if not q.full():
        q.put_nowait("message 4")
    print(q.get(True,5))
if __name__=="__main__":
    main()

输出参考结果:

可以看到先进先出。

3、使用队列在进程间通信

举例说明:分别向队列中写入和读取数据

import time
from multiprocessing import Process
from multiprocessing import Queue
#向队列中写入数据
def write_fun(q1):
    if not q1.full():
        for i in range(4):
            message = "消息" + str(i)
            q1.put(message)
            print("写入:%s"%message)
#从队列中读取数据
def read_fun(q2):
    time.sleep(1)
    while not q2.empty():
        print("读取:%s"%q2.get(True,2))

def main():
    print("----------父进程开始了------------")
    q = Queue()    #初始化Queue 对象,最多可接收3条信息
    pw = Process(target=write_fun,args=(q,)) #实例化写入队列中的子进程,并且传递队列
    pr = Process(target=read_fun,args=(q,))#实例化读取队列中的子进程,并且传递队列
    pw.start()  #启动子进程,进行写入
    pr.start()
    pw.join()  #等待子进程执行结束
    pr.join()

    print("----------父进程结束了------------")

if __name__=="__main__":
    main()

输出结果参考:

今天先写学习到这里了,每天进步一点点。明天也要加油啊!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

力扣 142.环形链表Ⅱ【详细解释】

一、题目 二、思路 三、代码 /*** Definition for singly-linked list.* class ListNode {* int val;* ListNode next;* ListNode(int x) {* val x;* next null;* }* }*/ public class Solution {public ListNode detectCycle(ListNode hea…

javaWeb项目-ssm+jsp房屋出租管理系统功能介绍

本项目源码(点击下方链接下载):java-ssmjsp房屋出租管理系统实现源码(项目源码-说明文档)资源-CSDN文库 项目关键技术 开发工具:IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7 框架:ssm、Springboot 前端&#xff…

[含文档+PPT+源码等]精品基于springboot实现的原生Andriod大学校园食堂外卖系统App

基于Spring Boot实现的原生Android大学校园食堂外卖系统App的背景可以从以下几个方面进行阐述: 一、项目背景与需求 随着移动互联网技术的快速发展和智能手机的普及,大学生对于便捷、高效的校园生活服务需求日益增长。大学校园食堂作为学生们日常用餐的…

【电商项目】1分布式基础篇

1 项目简介 1.2 项目架构图 1.2.1 项目微服务架构图 1.2.2 微服务划分图 2 分布式基础概念 3 Linux系统环境搭建 查看网络IP和网关 linux网络环境配置 补充P123(修改linux网络设置&开启root密码访问) 设置主机名和hosts映射 主机名解析过程分析&…

【问题解决】——当出现0xc000007b和缺少mfc140.dll时,该怎么做才能让软件可以打开

目录 事情起因 问题处理 明确定义 填坑之路 最后我是怎么解决的(不想看故事直接到这里) 事情起因 最近想要重新安装西门子博途来做西门子的一些算法的时候,发现自己软件装的是V15.1的版本,而买的plc1200固件版本要求至少16以…

性能评测第一,阿里开源可商用AI模型Ovis 1.6使用指南,AI多模态大模型首选

什么是 Ovis 1.6 Gemma 2 9B? Ovis 1.6 Gemma 2 9B 是阿里国际AI团队推出的最新多模态大模型(Multimodal Large Language Model,MLLM)。该模型旨在结构化地对齐视觉和文本嵌入,能够处理和理解多种不同类型的数据输入&…

抑郁症自测量表 API 接口,洞察情绪状态

抑郁症是一种常见的心理疾病,会给患者的生活和工作带来很大的困扰。为了帮助人们更好地了解自己的情绪状态,有一种抑郁症自测量表(简称SDS),它是一种能够反映病人主观抑郁症状的自评量表。下面我们将通过调用抑郁症自测…

基于FreeRTOS的LWIP移植

目录 前言一、移植准备工作二、以太网固件库与驱动2.1 固件库文件添加2.2 库文件修改2.3 添加网卡驱动 三、LWIP 数据包和网络接口管理3.1 添加LWIP源文件3.2 Lwip文件修改3.2.1 修改cc.h3.2.2 修改lwipopts.h3.2.3 修改icmp.c3.2.4 修改sys_arch.h和sys_arch.c3.2.5 修改ether…

Linux·文件与IO

1. 回忆文件操作相关知识 我们首先回忆一下关于文件的一些知识。 如果一个文件没有内容,那它到底有没有再磁盘中存在?答案是存在,因为 文件 内容 属性,即使文件内容为空,但属性信息也是要记录的。就像进程的…

硬件产品经理的开店冒险之旅(下篇)

缘起:自己为何想要去寻找职业第二曲线 承接上篇的内容,一名工作13年的普通硬件产品经理将尝试探索第二职业曲线。根本原因不是出于什么高大上的人生追求或者什么职业理想主义,就是限于目前的整体就业形式到了40岁的IT从业人员基本不可能在岗…

【Python】selenium遇到“InvalidArgumentException”的解决方法

在使用try……except 的时候捕获到这个错误: InvalidArgumentException: invalid argument (Session info: chrome112.0.5614.0) 这个错误代表的是,当传入的参数不符合期望时,就会抛出这个异常: InvalidArgumentException: invali…

day-69 使二进制数组全部等于 1 的最少操作次数 II

思路 与3191. 使二进制数组全部等于 1 的最少操作次数 I思路类似,区别在于该题每次将下标i开始一直到数组末尾所有元素反转,所以我们用一个变量可以统计翻转次数 解题过程 从左向右遍历数组的过程中,有两种情况需要进行翻转:1.当…

多媒体(4)

PNG PNG(流式网络图像)文件采用【无损压缩】算法,压缩比高于GIF文件,支持 图像透明 PNG文件的色彩深度可以是灰度图像的16位,彩色图像的48位,是一种新兴的 网络图像格式 矢量图 矢量图是一组指令集合描述图…

Sentinel 介绍

随着微服务的流行,服务和服务之间的稳定性变得越来越重要。Sentinel 是面向分布式、多语言异构化服务架构的流量治理组件,主要以流量为切入点,从流量路由、流量控制、流量整形、熔断降级、系统自适应过载保护、热点流量防护等多个维度来帮助开…

芯知识 | NVH-FLASH语音芯片支持平台做语音—打造音频IC技术革新

随着科技的飞速发展,人们对于电子产品的音频性能要求越来越高。在这种背景下,NVH-FLASH系列语音芯片应运而生,作为音频IC领域的一次重大技术革新,NVH-FLASH系列语音芯片凭借其卓越的性能与灵活的支持平台,正逐步引领着…

Linux——网络层协议

前言 网络层:在复杂的网络环境中确定一个合适的路径 目录 前言 一IP协议 1预备知识 2基本概念 3格式 4网段划分 4.1理解IP 4.2IP组成 4.3划分方式 4.4为什么要网段划分 5特殊的IP地址 6IP地址的限制 7私有IP和公网IP 8NAT技术 9理解公网 10路由 …

使用RNN、LSTM和Transformer进行时间序列预测

文章目录 1 RNN & LSTMRNN结构LSTM结构样本和标签 2 Transformertransformer结构位置编码 1 RNN & LSTM RNN结构 LSTM结构 代码(使用CPU): import numpy as np import torch from matplotlib import pyplot as plt from torch impo…

SQLite 上手指南 -- 基础语法

目录 一、数据库操作1.1 新建数据库1.2 查看数据库1.3 查看帮助指令 二、表操作2.1 创建表2.2 表信息2.3 表索引信息2.4 表结构信息2.5 删除表 三、数据记录操作3.1 新增记录3.2 查看记录3.3 不同格式输出 四、运算符4.1 算术运算符4.2 比较运算符4.3 逻辑运算符4.4 位运算符 S…

【热门】用ChatGPT做智慧农业云平台——农业ERP管控系统

随着科技的进步,原有农业种植方式已经不能满足社会发展的需要,必须对传统的农业进行技术更新和改造。经过多年的实践,人们总结出一种新的种植方法——温室农业,即“用人工设施控制环境因素,使作物获得最适宜的生长条件,从而延长生产季节,获得最佳的产出”。这种农业生产方式…

Linux安装 php5.6

Linux安装 php5.6.30 下载-解压-配置-安装 下载到 /usr/local wget http://am1.php.net/distributions/php-5.6.30.tar.gztar -zxvf php-5.6.30.tar.gz cd php-5.6.30#编译配置 ./configure --prefix/usr/local/php --with-curl/usr/local/curl --with-freetype-dir --wit…