python中apply_python进程池中apply如何使用?

大家有没有考虑过可以直接用进程池去做任务呢?我们习惯性自己去处理一个任务,但是比较麻烦,如果可以制作一个进程自己去处理能实现吗?答案一定是肯定的,但是需要借助apply功能,大家知道要这个方法吗?知道怎么去使用吗?如果不了解的话,可以继续看下文了哦~

apply_async与apply区别:

lapply:添加任务后,等待进程函数执行完,

lapply_async:添加任务后,立即返回,支持回调;原型如下:#callback为回调函数

pools.apply_async(func, args=(), kwds={},

callback=None, error_callback=None,)

直接看例子:from multiprocessing import Pool

import time

import os

def func(*args, **kwargs):

# 定义进程函数

print('sub process id:', os.getpid())

time.sleep(1)

if __name__ == "__main__":

start = time.time()

# 创建进程池,进程数为4

pools = Pool(4)

for i in range(5):

# 添加任务

pools.apply_async(func)

# 关闭进程池,不在添加任务

pools.close()

pools.join()

print("cost time:", int(time.time()-start))

结果:sub process id: 15536

sub process id: 2788

sub process id: 20288

sub process id: 11020

sub process id: 15536

cost time: 2

现在大家应该知道怎么去使用apply这个方法了吧,害怕大家不清楚明白,还给大家准备了一个示例,大家可以看下示例演示,也可以很容易理解的哦~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值