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

Кстати да интересно можно ли написать рантайм в котором асинхронные

операции относятся к памяти а не к IO
условно куда там передавать cx.waker тогда?

13 ответов

4 просмотра

Для этого для начала понадобится процессор, который предоставляет асинхронные инструкции доступа к памяти.

А тут никакие префетчи не проканают? ЕМНИП эльбрусовский array prefetch buffer как раз асинхронно работает.

Недостаточно чтобы процессор сам по себе асинхронно работал -- нужны асинхронные инструкции, доступные программе.

Ну конкретно у APB есть вообще асинхронная программа, которую формирует компилятор... Так что вероятно под указанные критерии подходит.

А нельзя это реализовать через VM? Да, VM будет работать синхронно, но операции как бы будут асинхронными. правда я слабо себе это представляю

А ты на транзакционную память смотрел?

Понятно, что можно, просто смысла в этом нет. 🤷‍♀

"А это ИДЕЯ"

Я припоминаю (но это не точно) что процессор уже при чтении из памяти ведёт себя асинхронно, в том плане что - запустив команду чтения, не ждёт её окончания а выполняет что можно дальше до тех пор пока не понадобятся результат от команды чтения

Да, это и называется "суперскалярная архитектура". Вопрос в том, что программа этой асинхронности наблюдать, а значит, и использовать, не может.

Ну почему не может? Конечно может. Пусть у вас на C++ есть очень очень большой vector<int> m (не влезает в кэш) и некое большое n. Вам надо посчитать две суммы: a и b вот так: for (int i = 0; i < n; i++) a += m[f(i)]; for (int i = 0; i < n; i++) b += m[g(i)]; Где f и g это быстрые "псевдослучайные" функции, которые говорят какой элемент вектора m надо брать. Померьте скорость этого кода, а потом его сравните со скоростью вот такого кода, который считает тоже самое: for (int i = 0; i < n; i++) { int ia = f(i); int ib = g(i); a += m[ia]; b += m[ib]; } (Здесь вы "вручную" переписали код так, чтобы оба цикла выполнялись "параллельно")

после loop fusion код не всегда будет работать быстрее и не на всех платформах. Все будет зависеть от ширины кеш линий, размера элементов в массивах, заинлайнятся ли f() и g() и сколько кода они добавят, в общем много факторов

А почему кстати циклы не зафьюзились? Или сейчас llvm/gcc не умеют в loop fusion?

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

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

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Слушайте, ещё такая интересная задачка. Сделан аудит действий пользователей через триггеры в базе, соответственно каждый пользователь имеет свой логин и пароль в базе. Это пре...
Сергей Бычков
12
Кстати, раз про скачивание файлов разговор зашел) Сделал бота для себя (транскрибирующего и суммаризирующего встречи) но не ожидал что за 2 месяца 10к пользователей набежит😅...
Andrey Obolenskiy
8
вопрос по москвину - не понимаю вот такого вопроса похоже Сколько разных всегда завершающихся функций с типом a -> a -> b -> a -> a можно реализовать? Две функции одинаково...
Fedor
11
Скажите, тут нет проблемы? IMyInterface1 = interface function GetInterface2: IInterface2; ... function TMyInterface.GetInterface2: IInterface2; begin Result := TI...
Ruslan aka DUDE
18
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Утра доброго. Просветите пожалуйста. Хочу сделать rest сервер на делфи. Посмотрел 3 фреймворка: dmvc, Mars, mormot. Ни в одном из них не упоминается ассинхронная обработка вхо...
Сергей Бычков
10
Как попросить stack install делать executable без .exe на винде?
Danila Danko
9
Карта сайта