Библиотека собеса по Java | вопросы с собеседований
6.32K subscribers
396 photos
8 videos
437 links
Вопросы с собеседований по Java и ответы на них.

По рекламе: @proglib_adv

Учиться у нас: https://proglib.io/w/08c603b6

Для обратной связи: @proglibrary_feeedback_bot
Download Telegram
Что такое transaction propagation в Spring и какие виды существуют?

Propagation (передача транзакции) — политика того, как метод с аннотацией @Transactional будет взаимодействовать с существующей транзакцией.

Виды:

▪️ REQUIRED (по умолчанию): использует существующую транзакцию или создаёт новую, если её нет

▪️ REQUIRES_NEW: всегда создаёт новую транзакцию, при этом приостанавливая текущую

▪️ SUPPORTS: действует в рамках текущей транзакции, если есть, иначе без транзакции

▪️ MANDATORY: бросает исключение, если нет текущей транзакции

▪️ NEVER: запрещает наличие транзакции, если уже есть, бросает исключение

▪️ NESTED: создаёт «вложенную» транзакцию (savepoint внутри основной)

🐸 Библиотека собеса по Java

#spring
Please open Telegram to view this post
VIEW IN TELEGRAM
👍112🔥1👏1
DispatcherServlet в Spring Framework?

DispatcherServlet — это центральный компонент Spring MVC, который выступает в роли Front Controller.
Он принимает все входящие HTTP-запросы, перенаправляет их нужным контроллерам и формирует HTTP-ответ.

🔹 При получении запроса он:

— Определяет нужный Handler (контроллер) через HandlerMapping.

— Передаёт выполнение HandlerAdapter, который вызывает метод контроллера.

— Обрабатывает результат с помощью ViewResolver, чтобы вернуть клиенту нужное представление (например, HTML или JSON).

🐸 Библиотека собеса по Java

#spring
Please open Telegram to view this post
VIEW IN TELEGRAM
👍101🔥1
Что такое Lazy Initialization?

Lazy Initialization — это подход, при котором объект создаётся только в момент первого обращения к нему, а не заранее при инициализации класса или приложения.

Такой подход экономит ресурсы (память, CPU) и ускоряет старт программы, особенно если объект может так и не понадобиться.

🐸 Библиотека собеса по Java

#spring
Please open Telegram to view this post
VIEW IN TELEGRAM
👍91🔥1
Расскажите о проблеме N+1?

Проблема N+1 возникает при работе с ORM, когда для получения N сущностей с их связанными данными выполняется 1 запрос для основной коллекции и затем N дополнительных запросов для каждой связи.

Если у нас 100 пользователей, выполнится 101 запрос вместо одного.

Решения:

🔹 JOIN FETCH в JPQL:

@Query("SELECT u FROM User u JOIN FETCH u.orders")
List<User> findAllWithOrders();


🔹 EntityGraph:

@EntityGraph(attributePaths = {"orders"})
List<User> findAll();


🔹 Batch Size (не решает проблему, но группирует запросы):

@BatchSize(size = 10)
private List<Order> orders;


Выбор решения зависит от конкретной ситуации: для единичных запросов подходит JOIN FETCH, для повторяющихся паттернов - EntityGraph или Batch Size.

🐸 Библиотека собеса по Java

#spring
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5🔥42
Представь ситуацию?

Есть Spring Boot приложение с несколькими @Configuration классами, и в них определены бины с одинаковыми именами. Что произойдет при старте приложения и как разрешить конфликт?

🔹 Ответ:

Spring выбросит BeanDefinitionOverrideException при старте приложения.

Если нужно разрешить конфликт, есть несколько путей:

— Использовать @Primary
— Использовать @Qualifier
— Использовать профили (@Profile)

🐸 Библиотека собеса по Java

#spring
Please open Telegram to view this post
VIEW IN TELEGRAM
👍31🔥1