什么时候应该使用 Python 3.5 的 asyncio 的 `await` 功能,什么时候应该避免使用它?
何时使用和避免 Python 3.5 的 Asyncio 等待功能
Python 3.5 引入了await 关键字以方便使用 asyncio 进行异步编程。然而,并不总是清楚应该等待哪些操作来最大化效率。
确定异步候选者
经验法则是等待任何执行 I/ 的函数O 操作,如访问网络或读取文件。这些操作可能会长时间阻塞同步代码。通过等待它们,asyncio 可以同时执行其他操作。
异步代码的优点
如下面的代码片段所示,异步代码可以显着加快涉及以下操作的操作:多个 I/O 调用:
# Synchronous way: download(url1) # takes 5 sec. download(url2) # takes 5 sec. # Total time: 10 sec. # Asynchronous way: await asyncio.gather( async_download(url1), # takes 5 sec. async_download(url2) # takes 5 sec. ) # Total time: only 5 sec. (+ little overhead for using asyncio)
具有混合异步/同步代码的函数
异步函数可以调用异步和同步函数。但是,等待不执行 I/O 操作的同步代码没有任何优势。这可能会带来不必要的开销:
async def extract_links(url): # async_download() was created async to get benefit of I/O html = await async_download(url) # parse() doesn't work with I/O, there's no sense to make it async links = parse(html) return links
避免长时间运行的同步操作
避免异步内长时间运行的同步操作(> 50 ms)至关重要函数,因为它们可以冻结所有其他异步任务。要高效处理这些任务:
- 使用多重处理: 在单独的进程中执行长时间运行的操作并等待结果:
executor = ProcessPoolExecutor(2) async def extract_links(url): data = await download(url) links = parse(data) # Now your main process can handle another async functions while separate process running links_found = await loop.run_in_executor(executor, search_in_very_big_file, links)
- 使用 ThreadPoolExecutor: 对于 I/O 密集型同步任务,例如对 Web 服务器的请求:
executor = ThreadPoolExecutor(2) async def download(url): response = await loop.run_in_executor(executor, requests.get, url) return response.text
以上是什么时候应该使用 Python 3.5 的 asyncio 的 `await` 功能,什么时候应该避免使用它?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

Linux终端中查看Python版本时遇到权限问题的解决方法当你在Linux终端中尝试查看Python的版本时,输入python...

使用FiddlerEverywhere进行中间人读取时如何避免被检测到当你使用FiddlerEverywhere...

在使用Python的pandas库时,如何在两个结构不同的DataFrame之间进行整列复制是一个常见的问题。假设我们有两个Dat...

Uvicorn是如何持续监听HTTP请求的?Uvicorn是一个基于ASGI的轻量级Web服务器,其核心功能之一便是监听HTTP请求并进�...

如何在10小时内教计算机小白编程基础?如果你只有10个小时来教计算机小白一些编程知识,你会选择教些什么�...

攻克Investing.com的反爬虫策略许多人尝试爬取Investing.com(https://cn.investing.com/news/latest-news)的新闻数据时,常常�...
