170 похожих чатов

@Mkkt_Bkkt, а я ведь правильно понимаю, что lazy в принципе

реализует идею structured concurrency?

8 ответов

8 просмотров

Ну типо того, ну там ещё комбинаторы нужны, иначе сложно что-то написать, std::execution собственно про это в том числе, просто там стали делать не через корутины, а по сути колбеки, которые могут работать с корутинами

Пример кстати хреновый, так как это оверхед именно фьюч которые в стандартной библиотеке. Плюс они все равно так или иначе нужны для представления асинхронных, уже запущенных вычислений, это нужно например для таких алгоритмов как WhenAny Ну и вот пример бенчмарков нормальных фьюч и можно видеть насколько в стл все печально https://github.com/YACLib/Bench/tree/master/future/result/i7-11850H

magras- Автор вопроса
Arelav
Ну типо того, ну там ещё комбинаторы нужны, иначе ...

Комбинаторы это хорошо, но они не влият на основную идею structured concurrency (как ее вижу я) - строгую вложенность лайфтаймов корутин. Ну и конкретно std::executors до сих пор не поддерживает корутины из-за отсутствия отмены. На это жалуется и lazy, и executors.

magras
Комбинаторы это хорошо, но они не влият на основну...

Ну when_any like ее портит, идею в смысле, ну то есть оно вообще не вписывается нормально в structured concurrency. Там есть вариант с быстрой отменой всего что после первого, но такое себе на практике. Есть вариант с написанием асинхронной части поверх ленивой. std::execution поддерживает и отмены и корутины, по крайне мере если судить по libunifex, возможно не так как кому то хочется но это другой вопрос

magras- Автор вопроса
Arelav
Ну when_any like ее портит, идею в смысле, ну то е...

Я не уверен что знаком с последней ревизией, но проблема executors именно в том, что в них заложена отмена, а в корутины нет. В результате конечно можно обернуть корутину и просто игнорировать отмены, но я не готов назвать это поддержкой корутин. When_any, да, наверное это хороший пример демонстрирующий проблему structured concurrency подхода.

magras
Я не уверен что знаком с последней ревизией, но пр...

Поддержка корутин в том что sender awaitable, ну и в таком виде соорудить task like класс тривиально. А отмен на уровне sender условно в том что есть set_done + stop_token. И это же точно также работает внутри корутин. Например делает co_await в скедулер который уже остановлен и отменяешь всю последующую цепочку. (Кстати вроде в каких то из последних ревизий заменили set_done на set_canceled (вроде бы после доклада Ниблера)0)) Я в общем не вижу разницы написания с std::execution в колбечном then стиле, и корутинном где мы можем использовать co_await для асинхронного ожидания. Ну из плюсов линейный код, из минусов оверхед

magras- Автор вопроса

Все верно, но пока это обвязка внешняя, это создаст проблему совместимости разных библиотек. Именно поэтому важно интегрировать это в стандарт. И так плохо что будут два типа стандартных корутин, но иметь неограниченное множество еще хуже. Это же является ответом почему базовые асинхронные примитивы должны быть в стандарте. Вспомните войну асинхронных фреймворков в расте и представте, что даже future не был бы стандартизирован. С другой стороны до стандартизации future, был крейт являвщийся стандартом де факто. Не знаю на сколько это применимо к плюсам, где управление зависимостями до сих пор не так распространено.

Похожие вопросы

Обсуждают сегодня

@MrMiscipitlick А можешь макрос написать, который будет вычислять смещение относительно переданных меток? Просто .label1-.label2, и вернуть значение.
КТ315
35
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
А еще в перле можно уже @arr1 + @arr2?
Sergei Zhmylove
53
Подобного рода ;Следующие три строки это директивы ассемблера, ;которые можно не задавать, т.к.работаем в Visual Studio. ;Символ ";" - это начало однострочного комментария ...
Егор Анелькин
3
Привет всем. появился вопрос. Разрабатываю сайт, в данный момент он запущен. Хостинг beget. Добавляю на сайт яндекс метрику с помощью полей client-settings (взято отсюда http...
Andrew
2
Кто-нибудь знает почему SPM клонирует репо целиком? Некоторые репы просто огромные, как та же swift-syntax которая нужна для использования макросов. Сначала подумал, что это...
iMike
6
Подскажите, где смотреть результат выполнения программы? Код: ;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, станда...
Егор Анелькин
5
Привет. Я верно понимаю, что в определении класса Монад m — зафиксирован (к тому же поскольку это моноид в категории эндофункторов). Т.е. используя байнд я не могу перемещать...
Arseny
5
еще вопрос, допустим мы создадим char массив из 10 элементов и присвоим ему через сканф 10 символов. и выведем все символы. Хотел спросить последний элемент /0 будет включать...
Anthem
11
;.686 ;Система команд процессора 686 ;.MODEL FLAT,stdcall ;Модель памяти плоская, стандартный ;вызов процедуры ;option casemap:no...
Егор Анелькин
1
Карта сайта