python进程池中的回调函数

什么是回调函数

指定一个任务后、并且指定一个回调函数后,当指定的进程池执行的任务结束后,会将该任务的返回值作为回调函数的参数传递到回调函数中,并且回调函数得以执行

回调函数在主进程中被执行

 import os
 from multiprocessing import Pool


 def func1(n):
     print('in func1', os.getpid())
     return n * n

 def func2(nn):
     print('in func2 %s ' % os.getpid())
     print(nn)

 if __name__ == '__main__':
     pool = Pool(4)
     pool.apply_async(func1, args=(10, ), callback=func2)    # calback为回调参数,可以指定一个回调函数,这里指定回调函数为func2
     pool.close()
     pool.join()
     print(os.getpid())

10个任务func1投入到含有4个进程的进程池中异步执行,并且指定回调函数为func2,当投入到进程池中的每个任务执行完后,都会将返回值作为参数返回给回调函数,并且回调函数在主进程得以执行
执行了10次func1、10次func2

from multiprocessing import Pool

def func1(n):
    print('in func1')
    return n * n

def func2(nn):
    print('in func2')
    print(nn)

if __name__ == '__main__':
    pool = Pool(4)
    for i in range(10):
        pool.apply_async(func1, args=(10, ), callback=func2)    # calback为回调参数,可以指定一个回调函数,指定进程池执行的任务结束后,会将任务的返回值作为参数传递给回调函数,并执行回调函数,回调函数是在主进程中得以执行的
    pool.close()
    pool.join()

一般在爬虫中,用到回调函数比较多,并且是将访问网页、下载网页的过程放到子进程中去做,分析数据,处理数据让回调函数去做,因为访问网页与下载网页有网络延时,而处理数据只占用很小的时间

原文链接:https://www.cnblogs.com/xxpythonxx/p/17321346.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:python进程池中的回调函数 - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • Python内建类型list源码学习

    以下是详细讲解“Python内建类型list源码学习”的完整攻略。 在Python中,list是一种非常常用的数据类型,它可以存储多个值,并且可以进行添加、删除、修改等操作。本文将介绍Python内建类型list的源码实现,并提供两个示例说明。 list源码实现 定义 Python的源码中,list的定义如下: typedef struct { PyObje…

    python 2023年5月13日
    00
  • Python排序算法实例代码

    下面就给您详细讲解“Python排序算法实例代码”的完整攻略: 一、排序算法简介 排序算法(sorting algorithm)是计算机程序中最基础的算法之一,它是指将一组无序的数据元素,按照某种规则进行排列的过程。 常见的排序算法包括冒泡排序、选择排序、插入排序、快速排序、归并排序等,它们的实现方式不同,但总体思路都是通过比较和交换元素位置来完成排序的。 …

    python 2023年5月31日
    00
  • 深入浅析Python 命令行模块 Click

    深入浅析Python 命令行模块 Click 什么是 Click Click 是一个 Python 的第三方包,可以帮助我们快速地创建命令行界面。它有几个显著的特点,比如自动帮助信息生成、约束参数类型、简单易用的语法等等。 安装 Click 安装 Click 很简单,可以使用 pip 命令来进行安装: pip install click Click 的基本使…

    python 2023年5月20日
    00
  • python人工智能深度学习算法优化

    下面是详细讲解“Python人工智能深度学习算法优化”的完整攻略,包括算法优化方法、Python实现和两个示例。 算法优化方法 深度学习算法优化是通过改进算法的训练过程,提高模型的性能和泛化能力。常见的深度学习算法优化方法包括以下几种: 1. 正则化 正则化是一种常用的深度学习算法优化方法,其主要思想是对模型参数进行约束,避免模型过拟合。常见的正则化方法包括…

    python 2023年5月14日
    00
  • Python解决多进程间访问效率低的方法总结

    我为你详细讲解“Python解决多进程间访问效率低的方法总结”的完整攻略。 什么是多进程间访问效率低的问题? 在使用Python进行多进程编程时,我们经常会遇到多个进程之间需要共享数据的情况。但是,多进程之间的数据共享涉及到了进程之间的通信问题,进程通信又与操作系统的调度和内存管理密切相关。因此,多进程间数据共享往往会导致访问效率低下,程序性能受到很大影响。…

    python 2023年5月19日
    00
  • python实现随机森林random forest的原理及方法

    简介: 随机森林(Random Forest)是一种集成学习(Ensemble Learning)方法,通过训练多个决策树,通过投票的方式来决定最终分类结果。它在机器学习中是一个非常常用的算法,尤其适用于分类问题。 下面是 Python 的实现随机森林的原理及方法的攻略: 随机森林的原理 随机森林的主要思想是,通过训练多个决策树来得到一个强大的集成学习模型。…

    python 2023年6月3日
    00
  • 详解Python中的内建函数,可迭代对象,迭代器

    详解Python中的内建函数、可迭代对象、迭代器 Python作为一门高级编程语言,提供了很多内建函数、可迭代对象、迭代器等重要概念,下面我们详细讲解它们的用法和作用。 内建函数 Python提供了很多内建函数,这些函数是由Python开发者提供的,使用这些函数可以方便地完成一些基本操作和常用计算。常见的内建函数包括: print(): 打印输出内容到控制台…

    python 2023年5月13日
    00
  • python向字符串中添加元素的实例方法

    Python中,字符串是一个不可改变的序列。因此,你不能直接向字符串中添加元素,但是你可以通过创建新字符串的方法来向字符串中添加字符。 在Python中,字符串有一个名为join的方法,用于将一些字符串连接成为一个新的字符串。join方法将一个字符串列表作为参数,返回一个将列表元素连接起来的新字符串。 以下是join方法的语法: string = str.j…

    python 2023年6月5日
    00
合作推广
合作推广
分享本页
返回顶部