首页 > 系统相关 >进程间通信(管道)

进程间通信(管道)

时间:2024-04-09 20:49:17浏览次数:21  
标签:right 间通信 管道 进程 conn1 品尝 conn 大厨

进程间通信(管道)

一、关于创建管道的类

(1)创建管道的类

  • Pipe([duplex])
    • 在进程之间创建一条管道,并返回元组(conn1,conn2),其中conn1,conn2表示管道两端的连接对象
    • 强调一点:必须在产生Process对象之前产生管道
    • duplex
      • 默认管道是全双工的,如果将duplex射成False,conn1只能用于接收,conn2只能用于发送。

(2)主要方法

  • conn1.recv()
    • 接收conn2.send(obj)发送的对象
    • 如果没有消息可以接收recv就会一直处于阻塞状态
    • 如果连接的另一端已经关闭,那么recv方法就会抛出EOFError异常、
  • conn1.senf(obj)
    • 通过连接发送对象。obj是与序列化兼容的任意对象

(3)次要方法

  • conn1.close()
    • 关闭连接。如果conn1被垃圾回收,将自动调用此方法
  • conn1.fileno()
    • 返回连接使用的整数文件描述符
  • conn1.poll([timeout])
    • 如果连接上的数据可用,返回True
    • timeout指定等待的最长时限,如果省略此参数,方法将立即返回结果
    • 如果将timeout射成None,操作将无限期地等待数据到达
  • conn1.recv_bytes([maxlength])
    • 接收c.send_bytes()方法发送的一条完整的字节消息
    • maxlength指定要接收的最大字节数
    • 如果进入的消息,超过了这个最大值,将引发IOError异常,并且在连接上无法进行进一步读取
    • 如果连接的另外一端已经关闭,再也不存在任何数据,将引发EOFError异常
  • conn.send_bytes(buffer [, offset [, size]])
    • 通过连接发送字节数据缓冲区,buffer是支持缓冲区接口的任意对象,offset是缓冲区中的字节偏移量,而size是要发送字节数
    • 结果数据以单条消息的形式发出,然后调用c.recv_bytes()函数进行接收
  • conn1.recv_bytes_into(buffer [, offset]):
    • 接收一条完整的字节消息,并把它保存在buffer对象中,该对象支持可写入的缓冲区接口(即bytearray对象或类似的对象)
    • offset指定缓冲区中放置消息处的字节位移
    • 返回值是收到的字节数
    • 如果消息长度大于可用的缓冲区空间,将引发BufferTooShort异常
    • 基于管道实现进程间通信(与队列的方式是类似的,队列就是管道加锁实现的)

三、代码实现

[1]基于管道实现进程间通信

from multiprocessing import Process, Pipe


def producer(p_conn, name):
    left_conn, right_conn = p_conn
    right_conn.close()
    for i in range(5):
        data = f'{name}大厨烹饪的美食{i + 1}'
        left_conn.send(data)
    left_conn.close()


def customer(p_conn):
    left_conn, right_conn = p_conn
    left_conn.close()
    while True:
        try:
            data = right_conn.recv()
            print(f'消费者品尝了{data}')
        except EOFError:
            print('品尝结束!')
            right_conn.close()
            break


def main():
    # 创建管道必须在创建子进程之前
    left_conn, right_conn = Pipe()
    p_list = []
    # 创建消费者子进程
    customers = Process(target=customer, args=((left_conn, right_conn),))
    # 创建生产者子进程
    xanadu = Process(target=producer, args=((left_conn, right_conn), 'Xanadu',))
    p_list.append(xanadu)
    bridge = Process(target=producer, args=((left_conn, right_conn), 'bridge',))
    p_list.append(bridge)
    p_list.append(customers)
    p_list_new = []
    for p in p_list:
        p.start()
        p_list_new.append(p)
    for p in p_list_new:
        p.join()

    print('这是主进程!')


if __name__ == '__main__':
    main()
    
    
"""
消费者品尝了Xanadu大厨烹饪的美食1
消费者品尝了Xanadu大厨烹饪的美食2
消费者品尝了Xanadu大厨烹饪的美食3
消费者品尝了Xanadu大厨烹饪的美食4
消费者品尝了Xanadu大厨烹饪的美食5
消费者品尝了bridge大厨烹饪的美食1
消费者品尝了bridge大厨烹饪的美食2
消费者品尝了bridge大厨烹饪的美食3
消费者品尝了bridge大厨烹饪的美食4
消费者品尝了bridge大厨烹饪的美食5
"""

[2]管道通信特别注意

  • 生产者和消费者都没有使用管道的某个端点,就应该将其关闭,
  • 如在生产者中关闭管道的右端,在消费者中关闭管道的左端。
  • 如果忘记执行这些步骤,程序可能再消费者中的recv()操作上挂起。
  • 管道是由操作系统进行引用计数的,必须在所有进程中关闭管道后才能生产EOFError异常。
  • 因此在生产者中关闭管道不会有任何效果,付费消费者中也关闭了相同的管道端点。

标签:right,间通信,管道,进程,conn1,品尝,conn,大厨
From: https://www.cnblogs.com/taoyuanshi/p/18124734

相关文章

  • 进程间通信(队列和生产者消费者模型)
    进程间通信(队列和生产者消费者模型)一、关于进程间通信[1]什么是进程间通信(Inter-ProcessCommunication,IPC)进程间通信(Inter-ProcessCommunication,IPC)是指两个或多个进程之间进行信息交换的过程。它是一种计算机编程技术,用于在不同进程之间共享数据和资源。[2]如何实......
  • 进程池和线程池
    进程池和线程池一、什么是池无论是开设进程还是开设线程,都需要消耗资源只不过开始线程消耗的资源比开始进程相对少一些硬件的开发速度永远赶不上软件开发速度我们的宗旨是保证计算机硬件正常工作的情况下最大程度的利用它池是用来保证计算机硬件安全的情况下最大......
  • 驱动程序进程[chatgpt]
    在Windows操作系统中,驱动程序本身并没有进程号。进程号是与用户空间进程相关的标识符,用于标识正在运行的进程。然而,在驱动程序与进程之间可能存在一些关联。例如,驱动程序可能与特定的进程通信,或者驱动程序可能被特定的进程加载和使用。从驱动程序的角度来看,可以通过与用户空间......
  • 线上服务Java进程假死快速排查、分析
    服务器上的Java进程总是在运行个两三天后就无法响应请求了,具体现象如下:请求业务返回状态码502,查看进程还在,意味着Java进程假死,无法响应请求了;该Java进程占比CPU较高,高达132.8%。使用top命令查看服务器整体运行情况:可以看到PID为14760的Java进程CPU占比132.8%,内存占用37.6%,......
  • 【SpringBoot + Tomcat】请求到达后端服务进程后的处理过程
    1 前言这节我主要是想看下,Tomcat如何接收到请求并且是怎么一步步封装并交给SpringMVC处理的。这块之前一直没太深入的了解过,所以这节我们来看看。在看这节之前,你首先要清楚这两个问题,方便你更好的去理解。(1)SpringBoot启动的过程中,Tomcat的创建和启动时机是在什么时候呢?不......
  • 29_进程基础
    进程基础介绍进程[动态]指正在运行的程序(保持在存储介质上的,经过编译的,可执行的二进制文件[静态]),换句话说,进程是程序的执行过程。如下图示,进程是资源分配的最小单位,在某一时刻cpu只运行一个进程,通过时间片轮转切换来实现很多进程看似的"同时运行"。可以通过“ps”或......
  • 【新资讯】行云绽放与瀚高完成兼容性认证,携手推进国产化进程
    近日,深圳市行云绽放科技有限公司自研的产品行云管家堡垒机与瀚高软件公司通过共同测试,瀚高数据库管理系统V9.0与行云管家堡垒机V7完成了产品兼容性认证。此次认证的成功,进一步完善了行云管家堡垒机的产品适配能力,扩展了信创生态圈,助力用户更安全、更高效地完成等保,保障数据......
  • Linux编程中进程的概念和环境变量
    目录概述1认识进程1.1进程的定义1.2进程状态1.3进程的调用2进程环境2.1进程ID2.2父进程与子进程2.3UID和GID2.4环境变量2.4.1通过main函数参数获取环境变量2.4.2environ全局变量获取环境变量2.4.3getenv()函数获取环境变量2.5环境变量的作用3......
  • eletron主进程和窗口的互相通信
    窗口和渲染进程是相同的东西窗口向主进程传输数据渲染进程传值window.electron.ipcRenderer.invoke('aaa',{a:1,b:2});主进程接收-------数据写在createWindow函数后面的mainWindow.on下面ipcMain.handle('aaa',(a,b)=>{})主进程向窗口传值主进程-------数据写在c......
  • 如何设置有效的屏幕与进程浮水印?
    进程浮水印的设置至关重要,主要有以下几个原因:增加警示作用: 进程浮水印能够在进程中浮现出预设的水印,提醒用户当前开启的服务或软件正在访问重要数据。这种警示作用可在一定程度上避免用户无意间泄露敏感信息。防止泄密: 为防止解敏过程中的涉密信息被截屏捕获,进程浮水印的......