共计 648 个字符,预计需要花费 2 分钟才能阅读完成。
一、同步与异步的概念
-
前言
python 由于 GIL(全局锁)的存在,不能发挥多核的优势,其性能一直饱受诟病。然而在 IO 密集型的网络编程里,异步处理比同步处理能提升成百上千倍的效率
-
同步
指完成事务的逻辑,先执行第一个事务,如果阻塞了,会一直等待,直到这个事务完成,再执行第二个事务,顺序执行
-
异步
是和同步相对的,异步是指在处理调用这个事务的之后,不会等待这个事务的处理结果,直接处理第二个事务去了,通过状态、通知、回调来通知调用者处理结果
-
说明
假设用户访问一个网站并得到响应的时间为 5 秒,使用同步思想则一共需要 20 秒以上,那么使用异步思想则一共需要 5 秒左右
二、同步与异步代码
-
同步
import time def run(index): print("sunck is a good man", index) time.sleep(2) print("sunck is a nice man", index) for i in range(1, 6): run(i)
-
异步
说明:后面的课程中会使用到 asyncio 模块,现在的目的是使同学们理解异步思想
import asyncio import time # 定义一个异步函数(定义了一个协程) async def run(): print("sunck is a good man") # 模拟一个耗时 IO asyncio.sleep(2) print("sunck is a nice man") loop = asyncio.get_event_loop() for i in range(1, 5): loop.run_until_complete(run())
正文完
星哥玩云-微信公众号