进程池与线程池

1. 什么是池?安全

在保证计算机硬件安全的状况下最大限度的利用计算机,池实际上是下降了程序的运行效率,可是保证了计算机的硬件安全,不会形成计算机崩掉,服务器挂掉,受限于硬件的发展才有了池的概念,其实都是保证硬件的安全

2. 线程池与进程池服务器

线程池也就意味着一个池子,里面事先已经放好了线程,假如里面有十我的,十我的就是十个线程,里面有空的位置,就往里面走,假如来了第十一我的,那就在外面等着,等着这个池子里面的只要有一我的走了,就立马把外面
等的那我的叫到池子里面去。

 

from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor
import time
import os

# pool = ThreadPoolExecutor(5)  # 括号内能够传参数指定线程池内的线程个数
# # 也能够不传  不传默认是当前所在计算机的cpu个数乘5
pool = ProcessPoolExecutor()  # 默认是当前计算机cpu的个数
"""
池子中建立的进程/线程建立一次就不会再建立了
至始至终用的都是最初的那几个
这样的话节省了反复开辟进程/线程的资源
"""

def task(n):
    print(n,os.getpid())  # 查看当前进程号
    time.sleep(2)
    return n**2


def call_back(n):
    print('拿到了异步提交任务的返回结果:',n.result())
"""
提交任务的方式
    同步:提交任务以后 原地等待任务的返回结果 期间不作任何事
    异步:提交任务以后 不等待任务的返回结果(异步的结果怎么拿???) 直接执行下一行代码
"""

# pool.submit(task,1)  # 朝线程池中提交任务   异步提交
# print('主')
"""
异步回调机制:当异步提交的任务有返回结果以后,会自动触发回调函数的执行

"""
if __name__ == '__main__':

    t_list = []
    for i in range(20):
        res = pool.submit(task,i).add_done_callback(call_back)  # 提交任务的时候 绑定一个回调函数 一旦该任务有结果 马上执行对于的回调函数
        # print(res.result())  # 原地等待任务的返回结果
        t_list.append(res)

    # pool.shutdown()  # 关闭池子 等待池子中全部的任务执行完毕以后 才会往下运行代码
    # for p in t_list:
    #     print('>>>:',p.result())
相关文章
相关标签/搜索