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

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

Новые вопросы выходят регулярно.
Download Telegram
Вопрос

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

Ответ

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

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

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

Ответ

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

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

Расскажите, как добиться неизменяемости коллекции на практике. Какие конкретные классы и методы Java для этого используете? Приведите пример кода на уровне описания.

Ответ

Добиться неизменяемости коллекции в Java можно с помощью стандартных методов из класса Collections, таких как Collections.unmodifiableList(), unmodifiableSet() и других. Эти методы создают обертку над исходной коллекцией, предотвращая изменения через полученный объект, однако сама исходная коллекция может изменяться, если есть прямой доступ. Для полной неизменяемости можно использовать небходимые классы из пакета java.util.Immutable*, либо коллекции из Java 9 и выше, создаваемые методами List.of(), Set.of(), которые возвращают действительно неизменяемые объекты. Важно понимать, что неизменяемость зависит от типа коллекции и используемых методов, а также от того, не хранятся ли во вложенных объектах изменяемые данные.

#lexicon #собеседование #java #junior #java_fundamentals #backend
Вопрос

Как реализовать паттерн хранения данных 'шардинг' в NoSQL базе? Какие шаги нужно предпринять и какие подводные камни учитывать?

Ответ

Шардинг в NoSQL реализуется путем распределения данных по разным сегментам (шардам) на основе выбранного ключа шардирования, обеспечивая масштабируемость и снижая нагрузку на отдельные узлы. Основные шаги включают выбор подходящего шард-ключа с равномерным распределением данных, настройку механизма маршрутизации запросов к нужному шард-у и обеспечение репликации для отказоустойчивости. Следует учитывать риски связанные с несбалансированным распределением данных (горячие шард-ы), сложностью миграции данных при изменении шард-ключа и особенностями консистентности в распределенной системе.

#lexicon #собеседование #java #senior #backend_storage #backend #core
Вопрос

Какие методы аутентификации и авторизации вы применяете для защиты REST API? Приведите пример реализации токен-бейзед аутентификации.

Ответ

Для защиты REST API применяются методы аутентификации, такие как Basic Auth, OAuth 2.0, API ключи, и JWT (JSON Web Token) для токен-бейзед аутентификации. Токены позволяют серверу не хранить состояние сессии, передавая зашифрованные данные о пользователе в каждом запросе. В примере JWT создается сервером при логине, подписывается секретным ключом и возвращается клиенту, который добавляет токен в заголовок Authorization для последующих запросов. Сервер валидирует токен, проверяет подпись и разрешает доступ к ресурсам.

#lexicon #собеседование #java #middle #backend_http #backend #core
Вопрос

Опишите, какие конкретные методы и метрики вы анализируете в VisualVM или YourKit, чтобы определить узкие места в работе сборщика мусора и как на основе этого меняете настройки JVM.

Ответ

Для анализа сборщика мусора в VisualVM или YourKit используются метрики пауз GC (Pause Time), частота срабатываний, объём освобождаемой памяти и распределение поколений (Young/Old). Анализируются детали таких пауз, чтобы выявить долгие или частые сборки, вызывающие задержки. На основе этих данных корректируются параметры JVM, например, размеры heap, настройки GC алгоритма (G1, CMS и т.д.) или увеличение параллелизма, чтобы уменьшить задержки и повысить общую производительность приложения.

#lexicon #собеседование #java #senior #backend
Вопрос

Как вы реализуете коллекции с ограничением на типы элементов с помощью дженериков? Покажите пример создания и использования такой коллекции.

Ответ

Объясняется использование параметрических типов (дженериков) для создания коллекций, которые ограничивают типы элементов, обеспечивая безопасность типов на этапе компиляции. Показывается пример объявления коллекции с указанием типа, например, List<String>, и демонстрируется добавление и извлечение элементов без приведения типов. Подчеркивается, что дженерики позволяют избежать ClassCastException и улучшают читаемость кода.

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

📚 4000+ вопросов для подготовки к IT-собеседованиям
Вопрос

Как реализовать фильтр в Spring Security для логирования деталей каждого входящего запроса, и где лучше размещать такой фильтр в цепочке? Расскажите на примере.

Ответ

Для логирования деталей каждого входящего запроса в Spring Security создают кастомный фильтр, реализующий интерфейс Filter или расширяющий OncePerRequestFilter. В методе doFilter или doFilterInternal нужно получить информацию из HttpServletRequest, сделать логирование и вызвать цепочку фильтров через filterChain.doFilter. Такой фильтр рекомендуется регистрировать перед стандартным фильтром UsernamePasswordAuthenticationFilter, чтобы логировать запросы до аутентификации.

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

📚 4000+ вопросов для подготовки к IT-собеседованиям
Вопрос

Какие starter'ы вы используете при создании веб-приложения на Spring Boot? Приведите примеры конкретных зависимостей и их ролей.

Ответ

Для создания веб-приложения на Spring Boot обычно используются стартовые зависимости (starters), которые упрощают конфигурацию проекта. Часто применяются spring-boot-starter-web для создания REST API и работы с веб-компонентами, spring-boot-starter-data-jpa для интеграции с базами данных через JPA, а также spring-boot-starter-security для организации безопасности приложения. Каждая зависимость включает набор настроек и библиотек, необходимых для соответствующей функциональности, что ускоряет разработку и обеспечивает стандартный подход.

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

📚 4000+ вопросов для подготовки к IT-собеседованиям