python2中多进程库multiprocessing.pool.ThreadPool.Pool使用

  • apply_asyncPool 对象的一个方法,用于异步地(非阻塞地)将任务提交到进程池中执行。

  • 它的作用是:

    • 将任务分配给进程池中的一个空闲进程。
    • 立即返回一个 AsyncResult 对象,而不等待任务完成。
    • 任务会在后台的某个进程中执行。

补充说明:

  • 异步执行apply_async 是非阻塞的,提交任务后会立即返回,不会等待任务完成。如果需要等待任务完成并获取结果,可以调用返回的 AsyncResult 对象的 get() 方法。
  • 进程池的优势:使用进程池可以避免频繁创建和销毁

代码如下,

py 复制代码
# -*- coding: utf-8 -*-
import os 
import sys 
import time 
from multiprocessing.pool import ThreadPool as Pool

def func1(i):
    time.sleep(0.5)
    res = i + 1
    return res 

if __name__ == "__main__":
    p = Pool(20)
    tasks = []
    for i in range(100):
        task = p.apply_async(func1, (i,))
        tasks.append(task) 
    p.close()
    p.join()
    print("tasks size: {}".format(len(tasks))) 
    
    results = []
    for task in tasks:
        result = task.get()
        results.append(result)
    print("results size: {}".format(len(results))) 
    print(results) 

    print("success!")
相关推荐
全栈凯哥几秒前
02.SpringBoot常用Utils工具类详解
java·spring boot·后端
狂师26 分钟前
啥是AI Agent!2025年值得推荐入坑AI Agent的五大工具框架!(新手科普篇)
人工智能·后端·程序员
星辰大海的精灵28 分钟前
使用Docker和Kubernetes部署机器学习模型
人工智能·后端·架构
MikeWe31 分钟前
C++宏的解析:从基础语法到实战场景
后端
向往技术的猫菜36 分钟前
Java必需要会的MySQL知识
后端
Frank_zhou39 分钟前
Java代码是如何运行起来的
后端
Victor35639 分钟前
MySQL(121)如何处理死锁问题?
后端
亚洲第一中锋_哈达迪39 分钟前
深入剖析 go-zero 分布式缓存
后端
Frank_zhou41 分钟前
多线程-sleep-yield-join
后端
error_cn42 分钟前
sysctl监控系统性能
后端