Python Pool类多进程 apply_async 异步变成了阻塞解决方法

本文探讨了Python中使用多进程池时出现的阻塞问题,通过具体代码示例,对比分析了apply_async结合get()方法导致的阻塞现象,并提供了一种改进方案,实现了真正的异步处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

出错代码:

if __name__ == '__main__':
    ip_arr=get_ip_list()
    pool=Pool(processes=4)
    for temp in ip_arr:
        res = pool.apply_async(check_ip,(temp,)).get()
        if res :
            ip_list.append(res )
    pool.close()
    pool.join() 
    print(arr)

这段代码运行会发现是阻塞运行的

原因是apply_async后面 get()等待线程运行结束才会下一个

而apply_async刚好又是异步以主程序为主的,所以这段代码实际变成了阻塞

改成:

if __name__ == '__main__':
    ip_arr=get_ip_list()
    pool=Pool(processes=4)
    for temp in ip_arr:
        arr.append(pool.apply_async(check_ip,(temp,)))
    pool.close()
    pool.join() 
    ip_list=[]
    for temp in arr:
        if temp.get():
            ip_list.append(temp.get())
    print(ip_list,len(ip_list))

当然有更好的方法来获取他的返回值,只是这个方法比较方便~

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值