Курс 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
- Синхронизация потоков с time.sleep()
- Отделение звука от видео
- Работа с контекстными переменными
- Модуль sys: основы
- Оператор умножения для вектора
- Работа с множествами в Python
- Область видимости переменных
- Поиск с библиотекой Google
- Нахождение пересечения множеств
- Экранирование символов в Python
- Хранение данных
- Создание класса в Python
- PATCH-запрос с библиотекой requests
- Сериализация объектов в Python
- Роль запятой в Python
- Официальный канал Python в Telegram
- Retrying в Python: повторные вызовы
- Операторы увеличения и уменьшения в Python
- Расчет времени выполнения программы
- Удаление элемента из списка в Python
- UserList в Python: Описание и примеры использования
- Принципы программирования
- Хэш-функции и метод цепочек
- CSV строка разделение в Python
- Метод ifloordiv для пользовательских классов
- Работа с deque из collections
- Назначение максимального и минимального значения переменной в Python.
- Сортировка в Python
- Модуль pprint: улучшение вывода данных
- Нан-рефлексивность в Python
- Функциональное программирование в Python
- Создание виртуальной среды
- Генерация QR-кодов с библиотекой qrcode
- Расчет времени выполнения кода
- Обработка исключений в Python
- Установка User-Agent в Python
- Фильтрация элементов с помощью islice
- Antigravity модуль
- Структура данных словарь в Python
- Сортировка в Python
- Преобразование символов с помощью map
- Работа с датой и временем в Python















