在CPU密集型任务中,Python的multiprocessing模块是突破GIL限制的关键工具。multiprocessing.Pool(进程池)和multiprocessing.Process(独立进程)是最常用的两种并行化方案,但其设计思想和适用场景截然不同。本文结合代码示例和性能对比,解析二者的核心差异及最佳实践。


一、multiprocessing.Process:精细控制单个进程

核心特性

  • 手动管理生命周期:通过start()启动进程,join()等待结束,适合非均质任务调度。
  • 跨平台限制:Windows系统需将进程代码包裹在 if __name__ == '__main__': 中,避免子进程递归创建。
  • 进程间通信(IPC):需借助QueuePipe或共享内存(如Value/Array)传递数据。

典型代码结构

from multiprocessing import Processdef worker(num):print(f"Worker {num} running")if __name__ == '__main__':processes = []for i in range(3):p = Process(target=worker, args=(i,))processes.append(p)p.start()  # 启动进程for p in processes:p.join()   # 阻塞至进程结束

适用场景
✅ 需要精确控制每个进程的任务逻辑
✅ 进程执行时间差异大(如实时响应外部事件)
✅ 复杂IPC需求(如双向数据流)


二、multiprocessing.Pool:批量任务的自动化调度

核心优势

  • 进程复用:固定数量的工作进程反复处理任务,避免频繁创建/销毁开销。
  • 任务分发API
    • map(func, iterable):阻塞式,按顺序返回结果
    • apply_async(func, args):非阻塞,通过get()异步获取结果。
  • 资源约束:通过processes参数限制并发数(默认等于CPU核心数)。

基础用法示例

from multiprocessing import Pool
import timedef task(msg):print(f"Start: {msg}")time.sleep(2)return f"End: {msg}"if __name__ == '__main__':with Pool(processes=3) as pool:   # 限制3个进程results = pool.apply_async(task, ("Hello", ))print(results.get())           # 阻塞等待结果# 批量提交任务multiple_results = [pool.apply_async(task, (i,)) for i in range(4)]print([res.get() for res in multiple_results])

关键操作

  1. pool.close():禁止新任务提交
  2. pool.join():等待所有子进程退出

适用场景
✅ 处理大量同构任务(如数据分块处理)
✅ 需要自动负载均衡
✅ 简化并行代码结构


三、Pool vs Process 关键差异总结
特性multiprocessing.Poolmultiprocessing.Process
进程管理自动维护进程池,复用工作进程手动创建/销毁单个进程
任务调度支持map/apply_async等高级分发需自行实现任务分配逻辑
阻塞行为apply为阻塞,apply_async为非阻塞完全依赖join()控制阻塞
内存开销较低(进程复用)较高(频繁创建新进程)
适用任务类型均匀任务(如批量计算)异构任务或需实时响应场景

四、性能陷阱与最佳实践
  1. 避免全局变量拷贝
    Pool的任务函数需可序列化,避免包含大对象(可通过initializer预加载资源):

    def init_pool():global large_data  # 子进程初始化时加载large_data = load_heavy_model()pool = Pool(initializer=init_pool)
    
  2. 进程池不适用复杂IPC
    Pool的任务函数无法直接使用multiprocessing.Queue,需改用Manager().Queue()

    from multiprocessing import Manager
    manager = Manager()
    task_queue = manager.Queue()  # 进程池安全的队列
    
  3. 超时控制与容错
    apply_async支持timeout参数,避免僵尸进程:

    result = pool.apply_async(long_task, args=(...))
    try:output = result.get(timeout=30)  # 30秒超时
    except TimeoutError:print("Task timed out")
    

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

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

相关文章

容器技术技术入门与 Docker 环境部署

目录 一:Docker概述 1、 Docker的优势: (1)环境一致性 (2)隔离性 (3)资源高效 (4)便捷性和可扩展性 2、Docker容器与传统虚拟机的区别 3、Docker的应用…

Oracle获取执行计划之DBMS_XPLAN 技术详解1

在 Oracle 数据库的管理与优化工作中,深入了解 SQL 语句的执行计划是至关重要的一环。DBMS_XPLAN 包作为 Oracle 提供的强大工具,能够帮助数据库管理员(DBAs)和开发人员清晰地查看和分析 SQL 语句的执行计划,从而实现对…

【Python】VScode配置Python教程

文章目录 【Python】VScode配置Python教程下载Python安装插件解决乱码彻底运行vscode安装python库 【Python】VScode配置Python教程 前言: 当「Python 编程潜力」遇上「VSCode 开发神器」,会点燃怎样的效率革命?试想这样的场景:你…

PowerBI HtmlContent生成表格

假设有销量表: 1.PowerBI 导入 Html Content对象&#xff0c;并拖入报表 2.新建度量值: 度量值 VAR colCount DISTINCTCOUNT(销量[产品]) VAR ColumnHeaders "<tr><th styleborder:1px solid black; padding:5px; text-align:center; colspan"&col…

【人工智能与机器人研究】基于运动数据时空特征提取的人类运动片段分割方法

导读 动作示教方法是非专家用户对人形机器人进行控制的可靠形式&#xff0c;而对人类动作数据的运动分割与理解是其前提。利用现有方法对所捕获人类运动原始数据进行关键帧提取与运动分割时&#xff0c;由于数据特征不明确&#xff0c;导致难以准确定位运动起始帧、结束帧及分…

ARM内核之CMSIS

1.什么是CMSIS&#xff1f; CMSIS&#xff08;Cortex Microcontroller Software Interface Standard&#xff0c;Cortex微控制器软件接口标准&#xff09;提供Cortex-M内核与软件之间的接口&#xff0c;即用户可以通过这些统一的接口&#xff08;函数API&#xff09;去访问底…

嵌入式软件面经(二)Q: Modbus协议CRC校验的方式是什么?它有哪些优势?

Modbus协议使用的CRC&#xff08;循环冗余校验&#xff09;是一种用于确保数据通信完整性和准确性的差错检测方法。在Modbus RTU通信中&#xff0c;CRC校验过程清晰明确&#xff0c;且被广泛应用于工业通信场景。 一、Modbus协议的CRC校验流程 &#xff08;一&#xff09;CRC计…

glib-object 中G_DEFINE_TYPE 宏都作了什么?

author: hjjdebug date: 2025年 06月 25日 星期三 15:35:26 CST descrip: glib-object 中G_DEFINE_TYPE 宏都作了什么? 文章目录 1. 测试代码2 给出它的展开式.3.说说它都生成了什么?3.1. my_foo_get_type() 函数3.2. static GType my_foo_get_type_once(void)3.3. my_foo_cl…

Alembic迁移系统初始化实战教程

下面是一份结构清晰、步骤明确的 基于 Alembic Pydantic SQLAlchemy 的数据库迁移系统初始化教程&#xff0c;非常适合初次搭建项目或团队规范流程参考。 &#x1f680; Alembic SQLAlchemy Pydantic 项目数据库迁移初始化教程 本教程将指导你如何从零初始化 Alembic 迁移…

灰度发布怎么保证数据库一致的

注&#xff1a; 以下内容来源于deepseek答案&#xff0c;生产环境以实际情况为主&#xff01; 在灰度发布中保证数据库一致的最优解需要同时满足安全性、低复杂度和高可操作性。结合多年实战经验&#xff0c;以下是最推荐的黄金方案&#xff08;适用于90%以上场景&#xff09;&…

不用vue,只用html,即可简单实现electron项目

为你提供一个 最简单的 Electron 项目模板&#xff0c;包含完整的代码、配置和打包说明。即使你是小白&#xff0c;也能快速上手。 1. 项目结构 /your-project├── main.js # Electron 主进程文件├── preload.js # 安全通信脚本&#xff08;可选&#xf…

C++11原子操作:从入门到精通

文章目录 一、什么是原子操作&#xff1f;二、为什么需要原子操作&#xff1f;三、C11中的<atomic>头文件四、基本使用1. 声明原子变量2. 基本原子操作 五、内存顺序&#xff08;Memory Order&#xff09;示例&#xff1a;使用内存顺序实现自旋锁 六、原子类型模板七、实…

深入解析Flink Local模式启动流程源码:揭开作业初始化的神秘面纱

在Flink的数据处理体系中&#xff0c;Local模式凭借无需依赖分布式集群资源的特性&#xff0c;成为开发测试阶段快速验证作业逻辑的利器。其启动流程的源码里&#xff0c;藏着从作业提交到任务执行的完整脉络。接下来&#xff0c;我们将深入关键代码段&#xff0c;逐行剖析Flin…

二刷 苍穹外卖 day06

HttpClient 用来提供高效的、最新的、功能丰富的支持HTTP协议的客户端编程工具包 作用&#xff1a; 发送HTTP请求 接受响应数据 应用场景&#xff1a; 当我们在使用扫描支付、查看地图、获取验证码、查看天气等功能时 其实&#xff0c;应用程序本身并未实现这些功能&#xff…

React第六十三节Router中BrowserRouter的用途及注意事项

前言 BrowserRouter 是 React Router 库的核心组件&#xff0c;用于实现单页面应用&#xff08;SPA&#xff09;的客户端路由。它利用 HTML5 History API 管理 URL&#xff0c;实现页面无刷新跳转。下面详细解释其用途、使用方法和代码示例&#xff1a; 一、BrowserRouter 核…

《Self-Adapting Language Models》(SEAL)代码阅读笔记

代码&#xff1a;https://github.com/Continual-Intelligence 脚本命令用法&#xff1a;knowledge-incorporation/README.md 生成self-edit数据 脚本&#xff1a;sbatch knowledge-incorporation/scripts/make_squad_data.sh vllm serve启动Qwen2.5-7B模型的服务。 执行self-e…

GelSight Mini视触觉传感器开发资源升级:触觉3D点云+ROS2助力机器人科研与医疗等应用

近日&#xff0c;GelSight宣布对其GelSight Mini视触觉传感器的GitHub支持页面进行重大更新&#xff0c;围绕3D点云重建、ROS2 集成及开发者支持体系推出三大核心升级&#xff0c;助力机器人触觉感知、工业检测及科研场景落地。 GelSight Mini视触觉传感器重磅发布&#xff01;…

6、做中学 | 三年级下期 Golang值类型相互转换

本次为操作文章&#xff0c;大部分都在讨论类型之间如何转换&#xff0c;使用的是内置方法进行调用执行&#xff0c;详细使用请移步至&#xff1a; go的API使用文档地址 https://studygolang.com/pkgdoc 一、数值类型相互转换 go中数值转换需要显示转换&#xff0c;不能隐式自…

019 高校心理教育辅导系统技术解析:构建心理健康守护平台

高校心理教育辅导系统技术解析&#xff1a;构建心理健康守护平台 在关注大学生心理健康成为教育重点的当下&#xff0c;高校心理教育辅导系统借助数字化技术整合多种功能模块&#xff0c;面向管理员、学生、教师三类角色&#xff0c;实现心理教育辅导工作的高效化与精准化。本…

【ArcGIS】土地资源单项评价

【ArcGIS】土地资源单项评价 一、土地资源单项评价1、评价思路 二、操作步骤1、处理环境设置2、地形坡度评价3、高程评价4、坡度高程叠加评价5、地形起伏度6、土地资源综合评价 一、土地资源单项评价 1、评价思路 &#xff08;1&#xff09;利用全域DEM计算地形坡度&#xff…