从孤岛到大陆:Python进程间通信,让你的代码世界不再有隔阂

简介: 【8月更文挑战第1天】在编程领域,Python进程曾像孤岛般各自运行于独立内存中。随项目复杂度增长,进程协同变得重要。Python提供了多种机制搭建这些孤岛间的桥梁。本文介绍四种常见进程间通信(IPC)方式:管道(Pipes)、队列(Queues)、共享内存(Shared Memory)及套接字(Sockets),并附示例代码展示如何实现信息自由流通,使进程紧密相连,共建复杂程序世界。

在编程的浩瀚宇宙中,每个Python进程曾像是一座座孤岛,各自运行在自己的内存空间内,互不相通。然而,随着项目复杂度的提升,进程间的协同工作变得至关重要。幸运的是,Python提供了多种机制,让这些孤岛能够搭起桥梁,形成一片广阔无垠的大陆,实现信息的自由流通。本文将带你探索几种常见的Python进程间通信(IPC)方式,并通过示例代码,展示如何打破隔阂,让代码世界紧密相连。

  1. 管道(Pipes)
    管道是Unix/Linux系统中一种最基本的IPC机制,它允许一个进程(写进程)将数据传输给另一个进程(读进程)。在Python中,可以通过multiprocessing模块中的Pipe()函数来创建管道。

python
from multiprocessing import Process, Pipe

def sender(conn):
conn.send(['hello', 'world'])
conn.close()

def receiver(conn):
print(conn.recv())
conn.close()

if name == 'main':
parent_conn, child_conn = Pipe()
p1 = Process(target=sender, args=(child_conn,))
p2 = Process(target=receiver, args=(parent_conn,))
p1.start()
p2.start()
p1.join()
p2.join()

  1. 队列(Queues)
    队列是另一种常用的IPC机制,它允许多个进程安全地存取数据。Python的multiprocessing.Queue是一个线程和进程安全的队列实现。

python
from multiprocessing import Process, Queue

def worker(q):
q.put('Hello World')

if name == 'main':
q = Queue()
p = Process(target=worker, args=(q,))
p.start()
print(q.get()) # 输出: Hello World
p.join()

  1. 共享内存(Shared Memory)
    对于需要高效传输大量数据的场景,共享内存是理想的选择。Python的multiprocessing.Value和multiprocessing.Array允许进程间共享基本数据类型和数组。

python
from multiprocessing import Process, Value, Lock

def increment(num, lock):
with lock:
num.value += 1

if name == 'main':
lock = Lock()
num = Value('i', 0)
p = Process(target=increment, args=(num, lock))
p.start()
p.join()
print(num.value) # 输出: 1

  1. 套接字(Sockets)
    虽然套接字通常用于网络间通信,但也可以用于同一台机器上的不同进程间通信。Python的socket模块提供了TCP和UDP套接字的支持。

python
import socket

def server():
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
s.bind(('localhost', 12345))
s.listen()
conn, addr = s.accept()
with conn:
print(conn.recv(1024).decode())

def client():
with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as s:
s.connect(('localhost', 12345))
s.sendall(b'Hello, server!')

if name == 'main':
from threading import Thread
t1 = Thread(target=server)
t2 = Thread(target=client)
t1.start()
t2.start()
t1.join()
t2.join()
通过这些IPC机制,Python进程间不再是孤立的岛屿,而是紧密相连的大陆,共同构建出更加丰富、复杂的程序世界。

相关文章
|
6天前
|
Python
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
以下是一些常用的图表类型及其Python代码示例,使用Matplotlib和Seaborn库。
|
1天前
|
数据安全/隐私保护 Python
探索Python中的装饰器:简化代码,提升效率
【9月更文挑战第32天】在Python编程世界中,装饰器是一个强大的工具,它允许我们在不改变函数源代码的情况下增加函数的功能。本文将通过直观的例子和代码片段,引导你理解装饰器的概念、使用方法及其背后的魔法,旨在帮助你写出更加优雅且高效的代码。
|
5天前
|
Python
? Python 装饰器入门:让代码更灵活和可维护
? Python 装饰器入门:让代码更灵活和可维护
11 4
|
5天前
|
缓存 测试技术 Python
探索Python中的装饰器:简化代码,提高可读性
【9月更文挑战第28天】在Python编程中,装饰器是一个强大的工具,它允许我们在不修改原有函数代码的情况下增加额外的功能。本文将深入探讨装饰器的概念、使用方法及其在实际项目中的应用,帮助读者理解并运用装饰器来优化和提升代码的效率与可读性。通过具体示例,我们将展示如何创建自定义装饰器以及如何利用它们简化日常的编程任务。
11 3
|
3天前
|
机器学习/深度学习 数据格式 Python
将特征向量转化为Python代码
将特征向量转化为Python代码
10 1
|
7天前
|
JavaScript 前端开发 Python
python执行js代码
本文档详细介绍如何安装Node.js环境及PyExecJS库,并提供示例代码展示其功能。首先,通过指定链接安装Node.js,安装完毕后可在命令行中输入`node --version`来验证安装是否成功。接着,使用`pip install PyExecJS`安装PyExecJS库,该库允许Python程序执行JavaScript代码。文档还提供了多个示例代码,展示了如何在Python环境中执行和编译JavaScript代码,并可以选择特定的JavaScript运行时环境,如Node.js或JScript。最后,通过具体案例展示了PyExecJS的功能与使用方法。
14 3
|
7天前
|
Java Linux Python
Linux环境下 代码java调用python出错
Linux环境下 代码java调用python出错
21 3
|
5天前
|
Python
Python 装饰器入门:让代码更灵活和可维护
Python 装饰器入门:让代码更灵活和可维护
10 1
|
6天前
|
Python
5-19|记录Python调用salt代码
5-19|记录Python调用salt代码
|
4天前
|
数据采集 Linux 调度
Python之多线程与多进程
Python之多线程与多进程
10 0
下一篇
无影云桌面