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

Привет. Скажите, есть ли в Котлин аналог parallelStream() джавовского? Сделал

аналог с помощью async awaitAll в цикле, но не уверен что это правильно.
Находил в Сети реализацию parallel Map, но она медленная.
https://jivimberg.io/blog/2018/05/04/parallel-map-in-kotlin/

5 ответов

18 просмотров

Можно брать прямо джавовский если это Kotlin-JVM, будет отлично работать. Для корутин из коробки пока нет, но можно посмотреть https://github.com/Kotlin/kotlinx.coroutines/issues/1147 и взять какое-то из предложенных решений

А почему это не может быть правильно? Просто я помню Елизаров на одном из докладов говорил, что корутины это не про async, но если вы хотите - то пожалуйста. Вот поэтому такой способ

Ilya
А почему это не может быть правильно? Просто я пом...

Для параллельного запуска самый простой вариант действительно async/awaitAll.

Mr Fox- Автор вопроса
Ilya
А почему это не может быть правильно? Просто я пом...

Не знаю, вдруг ошибаюсь. Вот тут - https://github.com/klesarev/blog-examples/blob/master/src/main/Lambda/Lambda.kt сравнивал способы, и метод с async получился самым быстрым. Подозрительно, но при запуске одновременно с parallelStream async быстрее его. Если запускать отдельно, то одинаково.

Mr Fox
Не знаю, вдруг ошибаюсь. Вот тут - https://github....

Parallel Stream будет выигрывать на нулевых операциях, потому что создание корутины не бесплатное. Но на любой реальной нагрузке будет уже примерно одинаково

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

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

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
28
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
День добрый, подскажите пожалуйста, есть ли какой-то способ сказать ребару не компилировать определённое приложение? Всю доку их перечиатл ничего подобного не нашёл
Кирилл
14
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
10
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
В clientsettings есть поле client_rates. В поле pagebuilder. Как получить то его?)
Andrey K
8
Здравствуйте, хочу сделать HelloWorld в консоли Дельфи, но функция API ничего не выводит, что я делаю не так? program Hello; {$APPTYPE CONSOLE} uses System.SysUtils, WinAPI.Wi...
Sergey Vinogradov
20
Вопрос на перед, на следующую пятницу. Сколько строк кода можно вешать на одного программиста, понятно что если проект хорошо написан то можно и миллион. Но есть же где то пре...
AlekseyK Kluchnikov
31
Немного оффтопа: а кто на чем сидит для осдева в плане ide/редактора? Последнее время сидел на vscode, но я его прям не могу нормально воспринимать, перешел на сlion, но меня...
Evg Resh
29
Карта сайта