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

Очень бы хотелось увидеть сравнение по производительности. Единственная фраза в

статье: thread::yield работает медленнее чем сохранение / восстановление контекста корутины.

Вы ведь наверняка не ввязались в корутины потому что модно, иначе бы на Go писали :))

Чисто в теории для меня поток и корутина отличаются только тем, что корутины не имеют thread local storage, поэтому не надо о нем думать. Ну и то, что у шедулера потоков чуть меньше объектов для обработки. Но зато у шедулера корутин больше (при этом первый работает на уровне ОС и я ему бы доверял больше). Остальные операции типа как сохранить регистры и стек общие для потоков и корутин. Откуда тогда профит?

3 ответов

13 просмотров

1. сохранять нужно только регистры, которые нужно сохранять при вызове функции (то есть гораздо меньше, чем при смене потока) 2. не надо уходить ядро может быть, еще что-то есть

переключение потока это сохранение/загрузка нескольких мегабайт данных. stackful корутины - килобайт. stackless - 1-2 указателей. Как думаешь, как соотносится быстродействие этих операций? )

Создавать корутины намного дешевле чем потоки Скорость переключения корутины vs переключения потока можно как раз прикинуть, сравнив производительности thread::yield. При этом thread::yield - хитрый системный вызов, у него есть hot path который почти ничего не делает. С ним и соревнуемся. Другие вызовы будут дороже (ну кроме хитрых вызовов через vdso). Учтите, что в последнее время переключение в режим ядра становится только дороже из-за уязвимостей процессоров.

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Карта сайта