视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
python中Tornado的同步与异步I/O的介绍(附示例)
2020-11-27 14:20:55 责编:小采
文档


本篇文章给大家带来的内容是关于python中Tornado的同步与异步I/O的介绍(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

协程是Tornado种推荐的编程方式,使用协程可以开发出简捷、高效的异步处理代码。

同步与异步I/O对比

众所周知,CPU的运行效率高于磁盘的存储,也高于网络请求,这就导致CPU对数据的处理和数据的存储或者网络请求(I/O操作)步伐不一致,此时可以选择I/O操作同步或者异步。

同步I/O操作,导致进程阻塞,直到I/O操作完成;

异步I/O操作,不会导致请求进程阻塞。

Tornado同步I/O的简单代码实例:

代码:

#导入Tornado的HTTP客户端
from tornado.httpclient import HTTPClient
def synchronous_visit():
 http_client=HTTPClient()
 #阻塞,知道对网址访问完成
 respone=http_client.fetch("http://www.baidu.com")
 print(respone.body)
synchronous_visit()

HTTPClient是Tornato的同步访问HTTP客户端。上述代码中的synchronous_visit()函数使用了典型的同步I/O操作来访问网址,该函数的执行时间取决于网络速度、对方服务器的响应速度,只有当访问完全结束并获取结果后,该函数才能执行完成。

Tornado异步I/O的简单代码实例:

from tornado.httpclient import AsyncHTTPClient
def handle_response(response):
 print(response.body)

def asyncronous_visit():
 http_client=AsyncHTTPClient()
 http_client.fetch("http://www.baoidu.com",callback=handle_response)

AsyncHTTPClient是Tornado的异步访问HTTP客户端。在上述代码中的asynchronous_visit()函数中使用了AsyncHTTPClient对第三方网站进行异步访问,http_client.fetch()函数会在调用后立刻返回而无需等待实际访问的完成,从而导致asynchronous_visit()也会立刻执行完成。当对网址的访问实际完成后,AsyncHTTPClient会调用callback参数指定的函数,可以在这个函数中处理访问结果。

下载本文
显示全文
专题