Python进程池回调

进程池在进程 发生错误/正常结束时,回调

python 复制代码
import multiprocessing, time
from functools import partial

def worker(i):
    print(f"Worker process {i} started")
    if i == 5:
        raise Exception(f'{i} error occured(自定义异常)')
    time.sleep(5)  # 模拟一些工作

def call_back_with_args(unknown_args, p):
    print('call_back p:', p, unknown_args)

def error_callback(e):
    print('error_callback : ', type(e), e)

if __name__ == '__main__':
    with multiprocessing.Pool(processes=6) as pool:
        for i in range(6):
            pool.apply_async(worker, args=(i,),
                             callback=partial(call_back_with_args, p=i),
                             error_callback=error_callback)

        pool.close()  # 关闭进程池,不再接受新的任务
        # time.sleep(2)
        # pool.terminate()  # 停止进程池中的所有工作进程,但不等待它们完成
        pool.join()

partial科普

相关推荐
YBCarry_段松啓25 分钟前
uv:下一代 Python 包管理器
人工智能·python
yorushika_28 分钟前
python打卡训练营打卡记录day45
开发语言·python·深度学习·tensorboard
封奚泽优30 分钟前
使用Python进行函数作画
开发语言·python
fc&&fl36 分钟前
大模型面试题总结
人工智能·python
databook44 分钟前
稀疏表示与字典学习:让数据“瘦身”的魔法
python·机器学习·scikit-learn
Sheeep1 小时前
学习Pytest + Hypothesis——能帮你发现你自己都没想到的 bug
python·测试
站大爷IP2 小时前
用Python打造办公效率神器:从数据到文档的全流程自动化实践
python
hongjianMa2 小时前
ModuleNotFoundError No module named ‘torch_geometric‘未找到
python
火兮明兮2 小时前
Python训练第四十五天
开发语言·python
zdy12635746882 小时前
python43天
python·深度学习·机器学习