组团学

同步与异步

阅读 (168152)

一、同步与异步的概念

  • 前言

    python由于GIL(全局锁)的存在,不能发挥多核的优势,其性能一直饱受诟病。然而在IO密集型的网络编程里,异步处理比同步处理能提升成百上千倍的效率

  • 同步

    指完成事务的逻辑,先执行第一个事务,如果阻塞了,会一直等待,直到这个事务完成,再执行第二个事务,顺序执行

  • 异步

    是和同步相对的,异步是指在处理调用这个事务的之后,不会等待这个事务的处理结果,直接处理第二个事务去了,通过状态、通知、回调来通知调用者处理结果

  • 说明

    假设用户访问一个网站并得到响应的时间为5秒,使用同步思想则一共需要20秒以上,那么使用异步思想则一共需要5秒左右

截屏2020011317.02.32.png

二、同步与异步代码

  • 同步

    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())
需要 登录 才可以提问哦