Lexicon | Java вопросы
13 subscribers
15 photos
14 links
Подготовка к собеседованиям для Java разработчиков.

Публикуем вопросы и разборы задач, которые встречаются на интервью backend разработчиков. Подходит для подготовки к позициям от junior до senior.

Новые вопросы выходят регулярно.
Download Telegram
📘 Разбор опроса

Анализ плана выполнения SQL-запроса

Вопрос: Что показывает explain plan для анализа производительности запроса?

Правильный ответ: План выполнения и операции СУБД

Explain plan показывает последовательность операций СУБД (сканирование, индексы, соединения) для оптимизации запроса.
👍1
Вопрос

Как ты объяснишь основное различие между checked и unchecked исключениями в Java, и почему важно это различие при проектировании API?

Ответ

Checked исключения требуют обязательной обработки или декларации с помощью throws, что обеспечивает явное управление ошибками на этапе компиляции. Unchecked исключения не требуют явного перехвата и обычно сигнализируют о проблемах, которые можно считать программными ошибками. При проектировании API важно различать эти типы исключений для балансировки контроля над ошибками и удобства использования, обеспечивая правильное информирование пользователей API о возможных ошибках.

#lexicon #собеседование #java #junior #java_errors #backend
👍1
📘 Разбор опроса

Эффективное кеширование в backend

Вопрос: Какой подход помогает избежать устаревших данных в кеше?

Правильный ответ: Регулярная инвалидация кеша

Инвалидация кеша при изменении данных предотвращает использование устаревших значений.
Вопрос

Как реализовать аутентификацию с помощью JWT в REST API? Опишите конкретные шаги и примеры использования.

Ответ

Аутентификация с помощью JWT в REST API включает создание и подпись токена при успешной проверке учетных данных пользователя, обычно после логина. Токен содержит полезную нагрузку с идентификатором пользователя и временем истечения, защищен секретным ключом. При последующих запросах сервер проверяет подпись и валидность токена из заголовка Authorization, что позволяет обеспечивать доступ к защищенным ресурсам без сессий. Важно реализовать обновление токенов и обработку ошибок в случае истечения срока действия или подделки токена.

#lexicon #собеседование #java #middle #backend_security #backend #core
📘 Разбор опроса

Spring Security: UserDetailsService

Вопрос: Какой метод нужно реализовать в UserDetailsService?

Правильный ответ: loadUserByUsername

Метод loadUserByUsername загружает данные пользователя по имени для аутентификации.
📘 Разбор опроса

Монолит vs Микросервисы: Простота развертывания

Вопрос: Что проще развернуть и тестировать?

Правильный ответ: Монолит

Монолит проще развертывать и тестировать из-за единой кодовой базы.
Вопрос

Опишите конкретный случай, когда выбор типа балансировщика нагрузки (например, Round Robin vs Least Connections) повлиял на производительность сервиса. Какие метрики и данные вы анализировали для этого решения?

Ответ

Выбор типа балансировщика нагрузки определяется распределением заданий между серверами и их текущей нагрузкой. Round Robin равномерно распределяет запросы без учёта загрузки, что подходит при одинаковой производительности узлов и равномерном трафике. Least Connections оптимизирует производительность в условиях разной загрузки серверов, направляя запросы на наименее загруженные. Для принятия решения анализируются метрики времени отклика, загрузки CPU и количества активных соединений для оценки эффективности балансировки.

#lexicon #собеседование #java #senior #backend_networking #backend #core
📘 Разбор опроса

Способы конфигурации бинов в Spring

Вопрос: Какие основные способы конфигурации Spring бинов?

Правильный ответ: XML, Java Config, аннотации

Spring поддерживает три основных подхода: XML, Java Config и аннотации. Они могут использоваться совместно.
Вопрос

Как используя volatile или Atomic-переменные, можно снизить вероятность race conditions? Расскажите с примерами.

Ответ

Использование volatile гарантирует видимость изменений переменной между потоками, предотвращая кэширование значений в рабочих потоках, но не обеспечивает атомарность операций. Atomic-переменные, такие как AtomicInteger, предоставляют атомарные методы для изменения данных без явной синхронизации, что снижает вероятность race conditions при обновлении счётчиков или флагов. Например, метод incrementAndGet() атомарно увеличивает значение, исключая состояния гонки. Такой подход упрощает многопоточное программирование, уменьшая необходимость использования synchronized блоков.

#lexicon #собеседование #java #junior #java_concurrency #backend