async 用来在python中使用协程
Python的线程虽然是真正的线程,但解释器执行代码时,有一个GIL锁:Global Interpreter Lock,任何Python线程在执行前,必须先获得GIL锁,然后,每执行100条字节码,解释器就自动释放GIL锁,让别的线程有机会执行。这个GIL全局锁实际上把所有线程的执行代码上了锁。所以,多线程在Python中只能交替执行,并不能做到真正的并发执行。
所以在python中,通常使用协程来代替多线程
"""
async 和 await
"""
import asyncio
import time
async def job1():
await asyncio.sleep(1)
print("job1 done")
async def job2():
await asyncio.sleep(2)
print("job2 done")
async def job3():
await asyncio.sleep(3)
print("job3 done")
def demo():
# 1. 创建一个事件循环
loop = asyncio.get_event_loop()
# 2. 将异步函数实例加入事件队列
tasks = [
job1(),
job2(),
job3()
]
# 3. 执行队列中的事件,直到最晚的一个事件被处理完毕
loop.run_until_complete(asyncio.wait(tasks))
# 4. 关闭事件循环
loop.close()
if __name__ == '__main__':
start = time.time()
demo()
print(f"cost {time.time()-start} seconds.")