chabapok ([personal profile] chabapok) wrote2025-02-23 09:36 pm

Корутины C++

В С++20 появились корутины

task<int> foo(){ ... }

int t = co_await foo();


Штука удобная, а стандарт написан так, что реализацию можно подставить какую хочешь. Это удобно. Но основная проблема - говорят, что человек может одновременно держать в голове 5..6 сущностей, программист - 7..8. Для реализации движка корутин нужно около 12.

Так с наскоку разобраться, как оно там под капотом работает, тяжело. Вроде все понятно, начинаешь делать - начинаются странности. При помощи ютуб - более-мене реально, но тоже сложно.

Я попытался сделать asyc/await движок с qt-шной очередью событий. (знаю про qcoro, но мне хочется понять, как оно сделано. А еще в qcoro нет await_all/await_first, и некоторые другие вещи не поддержаны). За 1 вечер нормально движок не сделать.
juan_gandhi: (Default)

[personal profile] juan_gandhi 2025-02-23 08:09 pm (UTC)(link)
Я когда-то очень давно имплементировал эту хрень для фортрана, попробовал использовать - и забил нах, навсегда. Нездоровая вещь.
juan_gandhi: (Default)

[personal profile] juan_gandhi 2025-02-23 08:47 pm (UTC)(link)
И эти потоки будут вызывать мой код в процессе? (Это то, что называлось корутинами (а также копрограммами) в древние времена.)
juan_gandhi: (Default)

[personal profile] juan_gandhi 2025-02-24 09:19 am (UTC)(link)
"эти" - это потоки, которым мы что-то передали.
Так ещё два вопроса. Передаём ли мы callback (тогда всё в порядке), или та корутина знает мои точки входа (тогда бардак, чисто с топологических соображений). Вот этот второй вариант и привёл меня когда-то к выводу, что лучше не надо.

Погуглил на вики. Да, я сильно против. Топология получается хреновая. Если что сломалось, то дыру не найти, вообще говоря.
juan_gandhi: (Default)

[personal profile] juan_gandhi 2025-02-24 11:43 am (UTC)(link)
А, ну так всё-таки обычные корутины. Если вынести на уровень микросервисов, то сервис А посылает что-то в точку сервиса Б, тот, подумав, посылает что-то в другую точку сервиса А - ну или с большим количеством участников.

Получаются обычные spaghetti. Которые нельзя алфавитно-топологически отсортировать. В которых может произойти бага, которую и теоретически невозможно локализовать. Это будет бюрократия, где не найти концов. (У нас в конторе примерно такая хрень, но у нас у разных групп сервисов репутации очень разные, и всегда можно свалить на "тех идиотов".)
juan_gandhi: (Default)

[personal profile] juan_gandhi 2025-02-24 01:47 pm (UTC)(link)
Ну, так-то всё норм; "скачать" не собирается разговаривать с тем процессом, который её позвал, пиная там что-нибудь, что он знает, что надо пинать. Я вижу тут иерархию; ну распаралеллена, и чо. Нормально.
juan_gandhi: (Default)

[personal profile] juan_gandhi 2025-02-24 02:53 pm (UTC)(link)
С генераторами понятно; в любом случае вызванный процесс сохраняет состояние, для данного клиента, ну и. Kind of against the restful ideology, but it's ok.

Still, it's all pretty innocent. Not the kind of coroutines I knew, where entities call each other with no control regarding who can call whom (and why).