当前位置: 首页 > article >正文

使用joblib 多线程/多进程

文章目录

  • 1. Joblib 并行计算的两种模式
    • 多进程(Multiprocessing,适用于 CPU 密集型任务)
    • 多线程(Multithreading,适用于 I/O 密集型任务)
  • 2. Joblib 的基本用法
  • 3. Joblib 多进程示例(适用于 CPU 密集型任务)
    • 示例:计算平方
  • 4. Joblib 多线程示例(适用于 I/O 密集型任务)
    • 示例:爬取网页
  • 5. 选择合适的并行模式
  • 6. 使用 parallel_backend 控制后端
  • 7. parallel_backend 与 Parallel 直接指定 backend 的区别
      • 区别

joblib 是一个 Python 库,用于高效的并行计算和缓存。它支持 多进程(multiprocessing) 和 多线程(multithreading),主要用于加速 CPU 密集型和 I/O 密集型任务。

1. Joblib 并行计算的两种模式

多进程(Multiprocessing,适用于 CPU 密集型任务)

每个任务在单独的进程中执行,避免 GIL(全局解释器锁)限制。
适用于 数值计算、矩阵运算、图像处理等 CPU 密集型任务。
后端:multiprocessing 或 loky(默认)。

多线程(Multithreading,适用于 I/O 密集型任务)

线程共享同一个进程,适用于 文件 I/O、网络请求、数据库查询等任务。
由于 Python 的 GIL,不适用于 CPU 密集型任务。
后端:threading。

2. Joblib 的基本用法

joblib 的并行计算主要通过 Parallel 和 delayed 来实现:

from joblib import Parallel, delayed

results = Parallel(n_jobs=4)(delayed(func)(x) for x in iterable)

n_jobs=4:使用 4 个线程或进程并行计算。
delayed(func)(x):将 func(x) 延迟执行,供 Parallel 并行调度。

3. Joblib 多进程示例(适用于 CPU 密集型任务)

示例:计算平方

import time

http://www.kler.cn/a/579229.html

相关文章:

  • WPF基础知识41-60
  • 【新人系列】Golang 入门(三):条件循环
  • P8641 [蓝桥杯 2016 国 C] 赢球票--环形结构问题
  • 深入理解人脸特征向量及图片转换方法与开发架构
  • 大白话react第十四章高阶 React 组件开发和React 状态管理进阶等
  • 第7章 wireshark(网络安全防御实战--蓝军武器库)
  • 2025-03-09 学习记录--C/C++-PTA 习题10-8 递归实现顺序输出整数
  • 一行代码让手机秒变 AI 神器:DeepSeek 手机离线部署
  • 每日一题——三道链表简单题:回文,环形合并有序
  • 大规模语言模型的涌现能力
  • 跟着 Lua 5.1 官方参考文档学习 Lua (10)
  • 智慧城市新基建:AI代理IP如何让城市管理“耳聪目明”?
  • 【07】区块链性能
  • 字符串相乘——力扣
  • vue如何获取session对象
  • docker已创建容器设置自启动
  • PY32MD320单片机 QFN32封装,内置多功能三相 NN 型预驱。
  • 记录小白使用 Cursor 开发第一个微信小程序(二):创建项目、编译、预览、发布(250308)
  • Vue3实战学习(Vue3集成Element-Plus(常用依赖、插件安装与导入 。按钮、图标组件。自定义主题的实现)(超详细))(4)
  • 开源网站模板 html静态网页模板