Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Java: parallel stream, performance, concurrency

Какие ограничения есть у параллельных стримов?

Проверяет понимание подводных камней параллельных стримов.

Короткий ответ

  1. Нет гарантии порядка обработки элементов.

  2. Накладные расходы на синхронизацию (медленнее на малых данных).

  3. Проблемы с shared state (например, несинхронизированные коллекции).

Длинный ответ

1. Порядок элементов

  • Последовательный стрим: [A, B, C] → [A1, B1, C1].

  • Параллельный стрим: [A, B, C] → [B1, A1, C1].

2. Производительность

  • Маленькие данные: Параллелизм может быть медленнее из-за накладных расходов.

  • Пример:

    List<Integer> numbers = List.of(1, 2, 3);
    // Неэффективно:
    numbers.parallelStream().map(x -> x * 2).toList();

3. Потокобезопасность

  • Ошибка:

    List<Integer> unsafeList = new ArrayList<>();
    IntStream.range(0, 1000).parallel().forEach(unsafeList::add); // Race condition!
  • Решение: Использовать потокобезопасные коллекции (Collectors.toList()).

Вывод:
Параллельные стримы полезны для больших данных и CPU-интенсивных задач.

Уровень

  • Рейтинг:

    1

  • Сложность:

    6

Навыки

  • Java

    Java

Ключевые слова

#parallel stream

#performance

#concurrency

Подпишись на Java Developer в телеграм