Python多进程中的数据隔离

Python 多进程(multiprocessing)中,子进程会完全复制主进程的内存数据,但是进程之间的变量、数据是完全独立、互不干扰的------ 修改一个进程里的数据,绝对不会影响其他进程。

这是进程和线程最大的区别:

  • 多线程:共享同一块内存,数据会互相影响,需要加锁
  • 多进程:内存完全隔离,数据独立,天然安全

进程拥有独立的内存空间

每个进程都有自己独立的栈、堆、全局数据区,互不共享。

如果需要进程间通信(共享数据)

既然默认隔离,那想让进程之间传递数据 / 共享数据,就必须用专门的机制

常用共享 / 通信方式

方式 用途
Queue 队列 进程间安全传递数据(最常用)
Pipe 管道 两个进程间双向通信
Value / Array 共享简单数值 / 数组
Manager 共享列表、字典等复杂对象
共享内存 高性能大数据共享

注意:Windows 没有 fork 机制,Python 多进程只能靠「重新导入模块」创建子进程,模块顶层所有代码、全局变量、函数、类都会被完整加载复制,跟主进程一样;
只有 if __name__ == '__main__' 内部代码不会在子进程执行。
(因为子进程的name不是main)

Python多进程执行时序

  1. 程序启动,先从头到尾执行整个 py 文件
    运行所有 if __name__ == '__main__' 外面的代码:全局变量定义、函数定义、顶层打印、赋值语句......
  2. 执行到 if __name__ == '__main__' 内部
    创建进程对象 Process()
  3. 调用 p.start() → 唤醒子进程
  4. 子进程内部:再次先跑一遍本文件所有 main 外语句
  5. 跑完所有外层语句后,才开始执行你绑定的子进程函数
相关推荐
甄心爱学习16 分钟前
【项目实训(个人11)】
python·个人开发
zhangfeng113324 分钟前
国家超算中心 htc 如果只有gpu资源 没有cpu资源 操作文件的时候会不会很卡呢
人工智能·pytorch·python·机器学习
jiayong2325 分钟前
01 检查 Python 版本与环境
开发语言·python
阿哟阿哟35 分钟前
vna.3.1.9.cn.jar设置成中文界面
python·pycharm·jar
XZ-07000138 分钟前
MySQL-综合应用(Python+Html)
python·mysql·html
噜噜噜阿鲁~1 小时前
python学习笔记 | 11.4、面向对象高级编程-定制类
笔记·python·学习
站大爷IP1 小时前
Python闭包变量作用域踩坑实录,原来我们都想错了
python
zzj_2626101 小时前
实验七 Python 文件操作与异常处理
开发语言·python
菜到离谱但坚持1 小时前
零门槛学LangChain:AI开发从入门到实战
python·langchain·prompt·rag
databook1 小时前
一次函数图像工厂:用 SymPy 自动生成 y=kx+b 对比动画
python·数学·动效