进程/线程池、协程、IO模型
1、进程池和线程池
multiprocessing为我们提供了一个Pool类,来为用户提供指定的进程数量 供用户调用: 1. 当有新的进程提交到Pool时,如果进程池没有满,那么就会创建一个新的进程执行请求, 2. 如果进程池已满,则会让请求先等待,直到有进程结束,才会执行该请求 注意: 池子中创建的进程/线程创建一次就不会再创建了 至始至终用的都是最初的那几个(可以通过查看进程号 来检验) 这样的话节省了反复开辟进程/线程的资源
通过concurrent.futures实现进程/线程池
# 代码演示(进程/线程池)+(异步回调) from concurrent.futures import ThreadPoolExecutor,ProcessPoolExecutor import time import os # 默认是当前计算机cpu的个数,也可以不传 不传默认是当前所在计算机的cpu个数乘5 pool = ThreadPoolExecutor(5) # pool = ProcessPoolExecutor() # 默认是当前计算机cpu的个数 def task(n): print(n,os.getpid()) # 查看当前进程号 time.sleep(2) return n**2 def call_back(n): print('拿到了异步提交任务的返回结果:',n.result()) """ 异步回调机制:当异步提交的任务有返回结果之后,会自动触发回调函数的执行 """ if __name__ == '__main__': for i in range(10): res = pool.submit(task,i).add_done_callback(call_back) # 提交任务的时候 绑定一个回调函数 一旦该任务有结果 立刻执行对于的回调函数 '''执行结果: 0 11600 1 11600 2 11600 3 11600 4 11600 拿到了异步提交任务的返回结果: 0 5 11600 拿到了异步提交任务的返回结果: 9 6 11600 拿到了异步提交任务的返回结果: 4 拿到了异步提交任务的返回结果: 1 7 11600 8 11600 拿到了异步提交任务的返回结果: 16 9 11600 拿到了异步提交任务的返回结果: 25 拿到了异步提交任务的返回结果: 49 拿到了异步提交任务的返回结果: 64 拿到了异步提交任务的返回结果: 36 拿到了异步提交任务的返回结果: 81 '''
2、协程
协程就是通过单线程实现并发
对比进程来理解: 进程:资源单位 线程:执行单位 协程:单线程下实现并发 并发 切换+保存状态 ps:看起来像同时执行的 就可以称之为并发 协程:完全是程序员自己意淫出来的名词 单线程下实现并发 并发的条件? 多道技术 空间上的复用(硬件资源的复用) 时间上的复用(切换+保存状态)