首页 > 编程语言 >python测试开发基础---multiprocessing.Pool

python测试开发基础---multiprocessing.Pool

时间:2024-09-06 17:52:04浏览次数:14  
标签:__ python --- Pool 进程 multiprocessing pool result

1. 基础概念

多进程编程:Python中的multiprocessing模块允许你使用多个进程并行执行任务,这可以提高程序的性能,尤其是在需要大量计算的情况下。Pool类是一个常用工具,可以帮助你更轻松地管理多个进程。

进程池:进程池是一个包含多个工作进程的池子,用来处理多个任务。你可以将任务分配给池中的进程,池会自动管理这些进程。

2. 使用方法

以下是multiprocessing.Pool的几个关键方法及其用法:

2.1 map(func, iterable)
  • 功能:将iterable中的每个元素传递给func函数,并返回包含结果的列表。
  • 适用场景:当你有一个可以被分解为多个独立任务的列表时。

示例

import multiprocessing

def square(n):
    return n * n

if __name__ == "__main__":
    # 创建一个进程池
    with multiprocessing.Pool() as pool:
        # 使用map将每个数平方
        results = pool.map(square, [1, 2, 3, 4, 5])
    print(results)  # 输出: [1, 4, 9, 16, 25]

解释

  • pool.map会将列表中的每个数字传递给square函数。
  • 计算结果将以列表形式返回。
2.2 apply(func, args=(), kwds={})
  • 功能:在一个工作进程中同步执行func函数,传递指定的参数,并返回结果。
  • 适用场景:当你只需要执行一个任务,并且任务不需要并行化时。

示例

import multiprocessing

def add(a, b):
    return a + b

if __name__ == "__main__":
    with multiprocessing.Pool() as pool:
        result = pool.apply(add, (10, 20))
    print(result)  # 输出: 30

解释

  • pool.apply会在池中的一个进程上执行add函数,传递1020作为参数。
  • 返回的结果是30
2.3 apply_async(func, args=(), kwds={}, callback=None)
  • 功能:异步执行func函数,返回一个AsyncResult对象,可以用来查询任务的状态和结果。
  • 适用场景:当你需要非阻塞地执行任务,并且可以处理异步结果时。

示例

import multiprocessing

def multiply(x, y):
    return x * y

def print_result(result):
    print(f"Result: {result}")

if __name__ == "__main__":
    with multiprocessing.Pool() as pool:
        async_result = pool.apply_async(multiply, (10, 5), callback=print_result)
        async_result.wait()  # 等待异步任务完成

解释

  • pool.apply_async会异步执行multiply函数。
  • callback参数指定一个回调函数,当异步任务完成后会调用这个函数。
2.4 starmap(func, iterable)
  • 功能:类似于map,但是iterable中的每个元素是一个参数元组,将这些元组解包并传递给func函数。
  • 适用场景:当你需要将多个参数传递给函数时。

示例

import multiprocessing

def power(base, exponent):
    return base ** exponent

if __name__ == "__main__":
    with multiprocessing.Pool() as pool:
        results = pool.starmap(power, [(2, 3), (3, 2), (4, 1)])
    print(results)  # 输出: [8, 9, 4]

解释

  • pool.starmap会将[(2, 3), (3, 2), (4, 1)]中的每个元组解包,传递给power函数。
  • 结果是[8, 9, 4]

3. 注意事项

  • 进程池管理:使用with语句创建Pool对象可以确保池在使用后被正确关闭,释放资源。如果不使用with,你需要手动调用pool.close()pool.join()
  • 线程安全:由于multiprocessing模块中的进程是独立的,因此通常不会发生线程安全问题。但需要注意的是,进程之间的数据共享可能需要使用multiprocessing.Manager等工具。
  • 性能考虑:进程之间的通信和数据交换是有开销的,因此并不是所有任务都适合使用多进程,尤其是任务非常简单或者数据量很小的时候。

标签:__,python,---,Pool,进程,multiprocessing,pool,result
From: https://blog.csdn.net/weixin_54641346/article/details/141952215

相关文章

  • js逆向--cai招网
    js逆向--cai招网一、寻找加密入口1、抓包2、关键字搜索寻找加密入口二、调试js三、python代码实现一、寻找加密入口1、抓包目标数据来源网址为:https://search.bidcenter.com.cn/search?keywords=%E5%85%AC%E5%85%B1%E4%BD%8F%E5%AE%85,打开开发者工具进行......
  • 最好用的Python IDE,PyCharm保姆级安装教程
    简介由于Python语法简单容易入门,并且Python在办公自动化等领域的功能非常强大,所以现在越来越多非IT行业的人也开始学起了Python,要学习和使用一门编程语言,一个好用的IDE是必不可少的,而对于Python来说,最好的IDE无疑是Pycharm。本文就给大家介绍一下如何从零到一来安装Pychar......
  • L2-049 鱼与熊掌 分数 25
    使用set_intersection()判断两个集合之间重复元素,时间复杂度最坏O(nlogn),最好O(n)#include<bits/stdc++.h>usingnamespacestd;intmain(){intn,m;cin>>n>>m;vector<set<int>>res(m+1);for(inti=1;i<=n;++i){......
  • Python贝叶斯卷积神经网络BCNN分类胸部X光图像数据集实例
    全文链接:https://tecdat.cn/?p=37604原文出处:拓端数据部落公众号分析师:YuanchunNiu在人工智能的诸多领域中,分类技术扮演着核心角色,其应用广泛而深远。无论是在金融风险评估、医疗诊断、安全监控还是日常的交互式服务中,有效的分类算法都是实现智能决策的关键。随着大数据时代的......
  • puthon-txt(1) 从txt读取gnss数据
     数据1453132356.60000034.0342694493108.755911045587.8002931453132357.96000034.0344383177108.755909682587.6737781453132358.52000034.0345050891108.755905295587.5684091453132359.16000034.0345823584108.755898876587.5876111453132359.56000034.......
  • 【Python学习笔记】第3章 你应如何运行程序
    这一章主要讲:如何启动Python程序、如何交互地输入代码、代码的各种运行方式。交互式命令行模式开始一个交互式会话在终端中,输入python:我们就开启了会话。结束会话按Ctrl+Z:系统路径如果我们要在终端中,输入python就可以启动,那么就需要设置环境变量PATH使其包含安装的python......
  • 信息学奥赛初赛天天练-84-NOIP2014普及组-基础题3-总线、存储器、邮件协议、二叉树、
    信息学奥赛初赛天天练-84-NOIP2014普及组-基础题3-总线、存储器、邮件协议、二叉树、满二叉树、顶点的度、无向图、有向图PDF文档公众号回复关键字:202409061NOIP2014普及组基础题36CPU、存储器、I/O设备是通过()连接起来的A接口B总线C控制线D系统文......
  • 『模拟赛』CSP-S模拟1
    Rank1BADA.喜剧的迷人之处在于签。正好早上还在改一个要分解质因数的题,所以一眼就出思路了。首先将\(a\)的平方因子全部除去,剩下的就是\(b\)必须的因数,即若设将平方因子全部除去后的\(a\)为\(a'\),则\(b\)应表示为\(a'\timesx^2\),从\(L\)这个下界开始只用找......
  • 高速背板连接器 249-4214-11V、249-4216-11V、249-4218-11V、249-4219-11V、249-421H-
    系列概述Paladin®HD系列延续了其作为行业领先的高速应用互连解决方案的传统。Paladin®HD2利用与PaladinHD相同的板连接、双轴电缆连接和配对接口实现向后兼容性,提供直接升级到224Gb/sPAM4的途径。分立屏蔽差分对和革命性的电路板技术实现了无与伦比的性能和密度。特性:世界级......
  • springboot 常用的验证框架分析 -shiro/springsecurity
    一 常用的认证鉴权框架关于认证和鉴权的框架,在springboot中使用比较多的比如shiro,springsecurity,soToken这些。从设计上,这些框架的底层逻辑其实大同小异。整体上来说:对于保护性的安全资源,用户需要先通过认证,才能获取授权访问,所以通过理解,很容易思考到,所有的权限管理框架。......