Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Java: executor, threadpool, concurrency

Стандартные способы управления потоками (ExecutorService, Future)

Вопрос проверяет знание современных способов работы с потоками.

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

ExecutorService - пул потоков для выполнения задач.
Future - результат асинхронной операции, позволяет:

  • Проверить готовность

  • Получить результат

  • Отменить выполнение

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

1. ExecutorService:

ExecutorService executor = Executors.newFixedThreadPool(4);

// Запуск задач
executor.execute(() -> System.out.println("Task 1"));
Future<Integer> future = executor.submit(() -> 42);

// Завершение
executor.shutdown();

2. Future:

if (future.isDone()) {
    int result = future.get(); // Блокирует до получения
}

// С таймаутом
try {
    future.get(1, TimeUnit.SECONDS);
} catch (TimeoutException e) {
    future.cancel(true);
}

Альтернативы:

  • CompletableFuture (Java 8+)

  • ForkJoinPool для рекурсивных задач

Уровень

  • Рейтинг:

    1

  • Сложность:

    7

Навыки

  • Java

    Java

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

#executor

#threadpool

#concurrency

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