Курс Python → Обмен данными с asyncio.Queue
Asyncio.Queue предоставляет удобный способ обмена данными между асинхронными задачами в Python. Он позволяет одной задаче помещать данные в очередь, а другой задаче забирать их для обработки. Это особенно полезно в случаях, когда необходимо организовать взаимодействие между разными частями программы, работающими параллельно.
Для использования asyncio.Queue необходимо создать объект класса asyncio.Queue(). Затем асинхронные задачи могут использовать методы put() для добавления элементов в очередь и get() для извлечения элементов из очереди. Кроме того, можно использовать методы task_done() для уведомления о завершении обработки элемента и join() для ожидания завершения обработки всех элементов очереди.
import asyncio
async def producer(queue):
for i in range(5):
await queue.put(i)
print(f'Producer put: {i}')
await queue.put(None)
async def consumer(queue):
while True:
data = await queue.get()
if data is None:
break
print(f'Consumer got: {data}')
queue.task_done()
async def main():
queue = asyncio.Queue()
producer_task = asyncio.create_task(producer(queue))
consumer_task = asyncio.create_task(consumer(queue))
await asyncio.gather(producer_task, consumer_task)
await queue.join()
asyncio.run(main())
В приведенном примере мы создаем две асинхронные задачи — producer, который помещает числа от 0 до 4 в очередь, и consumer, который извлекает и печатает эти числа. Когда producer завершает свою работу, он помещает значение None в очередь, чтобы consumer мог завершить свою работу. Мы используем asyncio.gather() для запуска обеих задач параллельно и await queue.join() для ожидания завершения обработки всех элементов очереди.
Другие уроки курса "Python"
- Именованные аргументы в Python
- Путь к интерпретатору Python
- Списки в Python
- Удаление файлов с shutil.os.remove()
- Циклы в Python
- Операции с датами в Python
- Просмотр атрибутов и методов класса
- Удаление ресурса в Python
- Математические функции в Python
- Метод remove() для удаления элемента из списка
- Объявление переменных в Python
- Метод __index__ в Python
- Гибкие функции Python
- Генераторы в Python
- Функция format() в Python
- Декораторы в Python
- Создание и удаление объектов
- Изменение переменной в Python: nonlocal
- Метод Enumerate() для списков
- Оптимизация памяти в Python
- Глобальные переменные в Python
- Объединение списков в Python.
- Оператор «or» в Python
- Объединение Python и Shell
- Метод join() для объединения строк
- Форматирование строк с помощью f-строк
- Импорт с альтернативным именем
- Работа с типами данных в Python с помощью pydantic.
- Получение обратного списка чисел
- Инверсия списка/строки в Python
- Участие в сообществе @selectel
- Именование переменных в Python
- Создание пар из последовательностей
- split() — разделение строки
- Типы возвращаемых значений в Python
- Функции в Python
- Принципы LSP и ISP в Python
- Основы слова
- Функция с **kwargs в Python
- Операции с комплексными числами
- Конструктор в Python
- Работа с файловой системой в Python
- Аннотации типов в Python
- Расчет времени выполнения
- Объединение строк с помощью метода join
- Псевдонимы в Python















