Отдельно разберём 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
Наконец-то лотерейный мясник для Соры готов :3 ✨ну, дядь, ты и испачкался
Было сложно, но я по... ну, закончила в общем! Было оч вкусно его лепить 🥩🫦
В будущем тоже сделаю ещё доп рендер, но саму модельку уже испекла и отдам
#kolori#zbrush
Коммишка для Атмосферы=) Оска Джун, собсно по киберпанку, сделал давно, но тут её не было...
ПС А ещё в тви залью крутой видосик, это я попозже сделаю, а в комменты кину небольшой гайдик по цветастому шейдеру в марме, ну кому интересно...обещал же тян
#AlexGray#zbrush#cyberpunk
Немного артово-технического 🥸
Намедни у меня башка болела с кольчугой + человек там спросил, как я её делала: в Зебре есть как минимум два стула способа с ней, очень похожие.
1ый: Micropoly в Dynamic subdive.
2ой: Через Nanomesh brush
(почему я в итоге выбрала второй, см. в комментах, если интересно)
А вы какие способы знаете? И вообще, как такие дела обстоят в других прогах?
#kolori#zbrush#учебник#mlarty#bg3#marrow