@hpklwbj · Post #148898 · 12.12.2025 г., 03:51
焦尼🌍北京外五 03年 92斤 175 D 极品洋娃娃支持指定验证 真人真照本人更好看 精致三庭五眼 最拿得出手的顶级女友 「 马甲线 蜜桃臀 漫画直腿 」 南方女孩 见多识广 高情商体贴哥哥 3粉氵超多 高学历 可英文交流 冷白皮肌肤无瑕疵 可纯可欲 热爱擅长❤️钢琴 吉他 绘画 游泳 高尔夫 马术 #苹果社区#B405#B #不✌️#外五
TGINSIGHT SIMILAR POSTS
Изворен канал @pythonotes · Post #402 · 22 дек.
Отдельно разберём TaskGroup, который пришел на замену gather в Python 3.11. Ключевые отличия ▫️create_task() возвращает объект asyncio.Task, у которого есть соответствюущие методы управления. То есть у нас больше контроля ▫️это контекстный менеджер, который гарантирует что все таски будут остановлены по выходу из контекста ▫️ошибка автоматически отменяет незавершенные задачи, ▫️except* передает нам ExceptionGroup, в котором каждую ошибку можно обработать отдельно import asyncio import random async def do_it() -> str: if random.random() < 0.1: raise ValueError('Oops') delay = random.uniform(0.5, 1.5) await asyncio.sleep(delay) return delay async def main(): try: async with asyncio.TaskGroup() as tg: for _ in range(10): tasks.append(tg.create_task(do_it())) for t in tasks: print(t.result()) except *ValueError as e: for err in e.exceptions: print(err) asyncio.run(main()) Рекомендую изучить страницу Coroutines and Tasks из документации, где представлено больше интересных примеров и механизмов - таймауты - отмена задач - создание задач из другого потока #async
Hashtags
Пребарај: #b405