Back to questions
IT One
Junior — Middle
67
Каким образом можно установить число потоков для выполнения параллельных операций в Stream API?
Companies where asked
Answer from AI
sobes.tech AI
В Java Stream API количество потоков, используемых для параллельных операций, контролируется через общий пул потоков ForkJoinPool.commonPool(). По умолчанию размер этого пула равен количеству доступных процессорных ядер.
Чтобы изменить число потоков для параллельного стрима, можно:
- Установить системное свойство
java.util.concurrent.ForkJoinPool.common.parallelismпри запуске JVM, например:
-Djava.util.concurrent.ForkJoinPool.common.parallelism=8
- Создать собственный ForkJoinPool с нужным уровнем параллелизма и запускать стрим внутри его контекста:
ForkJoinPool customThreadPool = new ForkJoinPool(8);
customThreadPool.submit(() -> {
list.parallelStream().forEach(...);
}).get();
Таким образом, напрямую в Stream API нельзя задать число потоков, но можно управлять пулом потоков, на котором выполняются параллельные операции.