进程池、线程池

线程池

#线程池
from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor
import random
from threading import current_thread

def fun(a,b):
    print(current_thread().ident,'start',a,b)
    time.sleep(random.randint(1,4))
    print(current_thread().ident,'end')

tb = ThreadPoolExecutor(4)   #实例化
for i in range(20):
    tb.submit(fun,i,b=i+1)   #向任务池中提交任务,submit提交参数(可以按位置传参或者关键字传参)

进程池

import os
import time
import random
from concurrent.futures import ProcessPoolExecutor

def fun(a,b):
    print(os.getpid(),'start',a,b)
    time.sleep(random.randint(1,4))
    print(os.getpid(),'end')

if __name__ == '__main__':
    tb = ProcessPoolExecutor(4)   #实例化
    for i in range(20):
        tb.submit(fun,i,b=i+1)   #向任务池中提交任务,submit提交参数(可以按位置传参或者关键字传参)
#map
import os
import time
import random
from concurrent.futures import ProcessPoolExecutor

def fun(a):
    b = a+1
    print(os.getpid(),'start',a,b)
    time.sleep(random.randint(1,4))
    print(os.getpid(),'end')
    return a*b

if __name__ == '__main__':
    tb = ProcessPoolExecutor(4)   #实例化
    ret = tb.map(fun,range(20))
    for key in ret:
        print(key)
##
#回调函数   效率最高
from threading import current_thread
import time
import random
from concurrent.futures import ProcessPoolExecutor

def fun(a,b):
    print(current_thread().ident,'start',a,b)
    time.sleep(random.randint(1,4))
    print(current_thread().ident,'end')
    return a*b

def print_fun(ret):             #异步阻塞
    print(ret.result())

if __name__ == '__main__':
    tb = ProcessPoolExecutor(4)   #实例化
    for i in range(20):          #异步非阻塞
        ret = tb.submit(fun,i,b= i+i)
        ret.add_done_callback(print_fun)  #ret这个任务在执行完毕的瞬间立即触发print_fun函数,并且把任务的返回值
                                        #对象传递到print_fun做参数
        #异步阻塞,回调函数给ret对象绑定一个回调函数,等待ret对应的任务有了结果之后立即调用print_fun这个函数
        #就可以对结果立即处理,而不用按照顺序接受结果处理结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值