Три способа выполнить множество задач с asyncio
Функция для примера:
async def do_it(n):
await asyncio.sleep(random.uniform(0.5, 1))
return n
1. Последовательный вызов
async def main():
for i in range(100):
result = await do_it(i)
Такой вызов имеет смысл только тогда, когда результат одной задачи требуется для вызова следующей.
Если они независимы, то это антипаттерн, так как аналогичен простому синхронному вызову по очереди.
2. Упорядоченный результат
async def main():
tasks = [do_it(i) for i in range(100)]
results = await asyncio.gather(*tasks)
Выполняет корутины конкурентно и возвращает результат в виде списка.
Полезен когда требуется получить результаты в том же порядке в котором задачи отправлены.
3. Результат по мере готовности
tasks = [asyncio.create_task(do_it(i)) for i in range(100)]
for cor in asyncio.as_completed(tasks):
result = await cor
Так же выполняет корутины конкурентно, но не гарантирует порядок. Результат возвращается по мере готовности, каждый отдельно.
Полезен когда нужно обработать любой ответ как можно скорее.
#async
告别“中间商”,PayPal 要自建银行
PayPal已在犹他州申请设立持牌工业银行,以加强对中小企业贷款、存款及支付业务的掌控。若获批,PayPal将能自主发放贷款、吸纳存款,并直接接入支付网络,减少对合作银行的依赖。这一举措也为其加密货币与稳定币业务扩张提供更稳固的金融基础。
标签:#paypal
Created by RocM
官方频道:@rocCHL
官方群组:@roctech
官方合作:@rocmmbot