Tornado 是一个基于 Python 的异步 Web 服务器框架,它使用了协程(coroutine)来实现异步编程。协程是一种轻量级的线程,可以在单个线程中实现并发执行。
Tornado 中使用的协程是基于 Python 的生成器(generator)实现的。生成器是一种特殊的函数,可以在执行过程中暂停并保存当前状态,等待下一次调用时恢复执行。在 Tornado 中,每个协程都是一个生成器对象。
Tornado 通过使用装饰器 @gen.coroutine 来定义协程。使用这个装饰器后,可以在协程中使用 yield 关键字来暂停执行,等待某个 IO 操作完成后再恢复执行。例如,下面的代码演示了如何在协程中使用 yield 来等待一个 HTTP 请求完成:
@gen.coroutine
def fetch_url(url):
response = yield AsyncHTTPClient().fetch(url)
print(response.body)
在这个例子中,yield 表示暂停执行,等待 HTTP 请求完成后再继续执行。AsyncHTTPClient().fetch(url) 是一个异步的 HTTP 请求,它会立即返回一个 Future 对象,表示请求的结果。当请求完成后,Future 对象的结果会被传递给 yield,然后协程会继续执行,打印请求的响应内容。
在 Tornado 中,Future 是一个占位符,表示某个尚未完成的操作的结果。Future 对象可以被赋值,也可以被等待,当 Future 对象被赋值后,等待该对象的协程会被唤醒并继续执行。例如,下面的