asyncio
是Python3.4
引入的标准库,直接内置了对异步IO
的支持。
asyncio
的编程模型是一个消息循环,从 asyncio
模块中获取一个 EventLoop
的引用,然后把需要执行的协程扔到 EventLoop
中执行,就实现了异步IO
。
- 当处理流出现
IO
阻塞时,线程并不会等待IO
操作执行完,而是去EventLoop
中执行下一个协程。
import asyncio
import time
import threading
# 1号协程
@asyncio.coroutine
def hello():
time.sleep(1)
print('我们如此相遇,我们如此分离', threading.currentThread)
yield from asyncio.sleep(1)
print('这世界已经改变我和你')
# 2号协程
@asyncio.coroutine
def bey():
time.sleep(1)
print('我想和你一样……', threading.currentThread)
yield from asyncio.sleep(1)
print('臭不要脸')
# 定义一个eventloop,可以理解为事件池,用于存放 协程
loop = asyncio.get_event_loop()
# 当只有一个协程时, 直接加入即可。
# loop.run_until_comp