Python多线程 Pool().apply_async

使用multiprocessing库,通过multiprocessing.Pool设置进程数,即 (processes=3)或者设置你自己的数量,如果池还没有满,就会创建一个新的进程来执行请求。如果池满,请求就会告知先等待,直到池中有进程结束,才会创建新的进程来执行这些请求。

import multiprocessing
def functest(x):
	函数体
if __name__ == "__main__":
    pool = multiprocessing.Pool(processes=3)
    # 动态循环添加进程
    for i in range(3):
	     print("------------------>", i)
	     # Pool().apply_async(要调用的目标,(传递给目标的参数,))
	     # 每次循环将会用空闲出来的子进程去调用目标
	     pool.apply_async(functest, (i,))
	# 或者直接添加,也可调用不同方法
	pool.apply_async(functest, (3,))
    pool.apply_async(functest, ([0,1,2], ))
    pool.apply_async(functest, ({0,3,4}, ))

	pool.close()
    pool.join()
    print("done.")
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值