Python 异步: 什么是事件循环 ?(6)

简介: asyncio 程序的核心是事件循环。在本节中,我们将花点时间看一下 asyncio 事件循环。

1. 什么是 Asyncio 事件循环

事件循环是用于在单个线程中执行协程的环境。事件循环是异步程序的核心。

它做了很多事情,例如:

  1. 执行协程。
  2. 执行回调。
  3. 执行网络输入/输出。
  4. 运行子进程。

事件循环是一种常见的设计模式,并且由于在 JavaScript 中的使用而在最近变得非常流行。

事件循环,顾名思义,就是一个循环。它管理一个任务列表(协同程序)并尝试在循环的每次迭代中按顺序推进每个任务,以及执行其他任务,如执行回调和处理 I/O。

“asyncio”模块提供了访问事件循环并与之交互的功能。这不是典型应用程序开发所必需的。

相反,为框架开发人员提供了对事件循环的访问,这些开发人员希望在 asyncio 模块之上构建或为其库启用 asyncio。

asyncio 模块提供了一个用于访问当前事件循环对象的低级 API,以及一套可用于与事件循环交互的方法。

低级 API 适用于将 asyncio 扩展、补充和集成到第三方库中的框架开发人员。我们很少需要与 asyncio 程序中的事件循环交互,而是使用高级 API。

尽管如此,我们还是可以简单地探讨一下如何获取事件循环。

2. 如何启动和获取事件循环

我们在 asyncio 应用程序中创建事件循环的典型方法是通过 asyncio.run() 函数。该函数接受一个协程并将执行它直到完成。我们通常将它传递给我们的主协程并从那里运行我们的程序。有用于创建和访问事件循环的低级函数。asyncio.new_event_loop() 函数将创建一个新的事件循环并返回对它的访问。

...
# create and access a new asyncio event loop
loop = asyncio.new_event_loop()

我们可以用一个有效的例子来证明这一点。

在下面的示例中,我们将创建一个新的事件循环,然后报告其详细信息。

# SuperFastPython.com
# example of creating an event loop
import asyncio
 
# create and access a new asyncio event loop
loop = asyncio.new_event_loop()
# report defaults of the loop
print(loop)

运行示例创建事件循环,然后报告对象的详细信息。我们可以看到,在这种情况下,事件循环的类型为 _UnixSelectorEventLoop 并且没有运行,但也没有关闭。

<_UnixSelectorEventLoop running=False closed=False debug=False>

如果 asyncio 事件循环已经在运行,我们可以通过 asyncio.get_running_loop() 函数访问它。

...
# access he running event loop
loop = asyncio.get_running_loop()

还有一个用于获取或启动事件循环的函数,称为 asyncio.get_event_loop(),但它在 Python 3.10 中已弃用,不应使用。

3. 什么是事件循环对象

事件循环作为 Python 对象实现。事件循环对象定义了事件循环的实现方式,并提供了与循环交互的通用 API,定义在 AbstractEventLoop 类中。不同平台的事件循环有不同的实现。例如,Windows 和基于 Unix 的操作系统将以不同的方式实现事件循环,因为在这些平台上实现非阻塞 I/O 的底层方式不同。

SelectorEventLoop 类型的事件循环是基于 Unix 的操作系统(如 Linux 和 macOS)的默认设置。

ProactorEventLoop 类型的事件循环是 Windows 上的默认设置。

第三方库可能会实现自己的事件循环以针对特定功能进行优化。

4. 为什么要访问事件循环

为什么我们要访问 asyncio 程序之外的事件循环?

我们可能希望从正在运行的 asyncio 程序外部访问事件循环的原因有很多。

  1. 监控任务的进度。
  2. 发布任务并从中获取结果。
  3. 解雇并忘记一次性任务。

asyncio 事件循环可以在程序中用作基于协程任务的线程池的替代方案。事件循环也可以嵌入到普通的 asyncio 程序中并根据需要访问。

相关文章
|
17天前
|
Python
深入理解 Python 中的异步操作:async 和 await
Python 的异步编程通过 `async` 和 `await` 关键字处理 I/O 密集型任务,如网络请求和文件读写,显著提高性能。`async` 定义异步函数,返回 awaitable 对象;`await` 用于等待这些对象完成。本文介绍异步编程基础、`async` 和 `await` 的用法、常见模式(并发任务、异常处理、异步上下文管理器)及实战案例(如使用 aiohttp 进行异步网络请求),帮助你高效利用系统资源并提升程序性能。
31 7
|
18天前
|
SQL 网络协议 安全
Python异步: 什么时候使用异步?
Asyncio 是 Python 中用于异步编程的库,适用于协程、非阻塞 I/O 和异步任务。使用 Asyncio 的原因包括:1) 使用协程实现轻量级并发;2) 采用异步编程范式提高效率;3) 实现非阻塞 I/O 提升 I/O 密集型应用性能。然而,Asyncio 并不适合所有场景,特别是在 CPU 密集型任务或已有线程/进程方案的情况下。选择 Asyncio 应基于项目需求和技术优势。
|
1月前
|
数据采集 JSON 测试技术
Grequests,非常 Nice 的 Python 异步 HTTP 请求神器
在Python开发中,处理HTTP请求至关重要。`grequests`库基于`requests`,支持异步请求,通过`gevent`实现并发,提高性能。本文介绍了`grequests`的安装、基本与高级功能,如GET/POST请求、并发控制等,并探讨其在实际项目中的应用。
57 3
|
3月前
|
关系型数据库 MySQL 数据处理
探索Python中的异步编程:从asyncio到异步数据库操作
在这个快节奏的技术世界里,效率和性能是关键。本文将带你深入Python的异步编程世界,从基础的asyncio库开始,逐步探索到异步数据库操作的高级应用。我们将一起揭开异步编程的神秘面纱,探索它如何帮助我们提升应用程序的性能和响应速度。
|
3月前
|
调度 Python
深入理解 Python 中的异步操作 | python小知识
在现代编程中,异步操作是一个非常重要的概念,尤其是在处理 I/O 密集型任务时。使用异步操作可以显著提高程序的性能和响应速度。Python 提供了 `async` 和 `await` 关键字,使得编写异步代码变得更加直观和简洁【10月更文挑战第8天】
46 2
|
3月前
|
数据采集 前端开发 NoSQL
Python编程异步爬虫实战案例
Python编程异步爬虫实战案例
90 2
|
2月前
|
NoSQL 关系型数据库 MySQL
python协程+异步总结!
本文介绍了Python中的协程、asyncio模块以及异步编程的相关知识。首先解释了协程的概念和实现方法,包括greenlet、yield关键字、asyncio装饰器和async/await关键字。接着详细讲解了协程的意义和应用场景,如提高IO密集型任务的性能。文章还介绍了事件循环、Task对象、Future对象等核心概念,并提供了多个实战案例,包括异步Redis、MySQL操作、FastAPI框架和异步爬虫。最后提到了uvloop作为asyncio的高性能替代方案。通过这些内容,读者可以全面了解和掌握Python中的异步编程技术。
56 0
|
3月前
|
网络协议 安全 Java
难懂,误点!将多线程技术应用于Python的异步事件循环
难懂,误点!将多线程技术应用于Python的异步事件循环
106 0
|
3月前
|
数据采集 JSON 网络协议
Python编程异步爬虫——aiohttp的使用
Python编程异步爬虫——aiohttp的使用
83 0
|
3月前
|
数据采集 调度 Python
Python编程异步爬虫——协程的基本原理(一)
Python编程异步爬虫——协程的基本原理(一)
28 0