штуку.
Собственно, есть массив с URL'ами. Не только с ними, но для данной задачи нужны только они.
Прога берет массив, ПООЧЕРЕДНО отправляет запросы на эти URL'ы, затем берет, обрабатывает и возвращает массив с результатами.
Что хочу сделать.
Хочу запихать все действия для отдельного запроса в одну функцию, функцию запихать в корутину, собрать все корутины для массива и запустить разом.
Цель всех этих плясок с бубном - сократить время ожидания ответа сервера. Не ждать пинг каждого запроса по отдельности, а подождать все вместе.
Как это можно сделать.
Насколько понял, в цикле по массиву это сделать не получится.
Что вы можете посоветовать?
urls.map{ URL(it).readText()}
корутины сами по себе конкурентностью не управляют, с тем же успехом можно просто отправить все урлы в ExecutorService
На выбор async + awaitAll или аналогичные средства из CompletableFuture
Если параллельно, то так urls.stream().parallel().map{URL(it).readText()}.toList()
Юзай шаблон веер-воронка. Реализацию см. тут https://kotlinlang.org/docs/channels.html Fan-in / Fan-out
Не надо блокирующий код через каналы дергать
Обсуждают сегодня