tgoop.com/Java_Iibrary/1814
Create:
Last Update:
Last Update:
Вопрос из Java-собеседования (сценарный):
Ты используешь @Autowired
для field injection в Spring-проекте. Это просто и работает.
@Component
public class UserService {
@Autowired
private UserRepository userRepository;
}
Тимлид просит тебя отрефакторить это, так как field injection часто считается плохой практикой.
Подумай о минусах field injection:
→ Visibility: скрывает обязательные зависимости класса.
→ Testability: усложняет unit-тестирование, часто требует рефлексии.
→ Runtime Issues: может привести к NullPointerException, если зависимость отсутствует.
→ Design: поощряет классы с чрезмерной ответственностью (нарушение SRP).
Какой рекомендуемый вариант?
→ Constructor Injection.
Зависимости явно передаются при создании объекта, делая их обязательными.
@Component
public class UserService {
private final UserRepository userRepo; // final!
public UserService(UserRepository userRepo) {
this.userRepo = userRepo;
}
}
Почему Constructor Injection лучше?
→ Explicit: явно показывает, что нужно классу для работы.
→ Guaranteed: приложение не поднимется, если зависимости нет.
→ Immutable: final-поля безопаснее и дружелюбнее к многопоточности.
→ Testable: легко замокать и прокинуть зависимости в тестах.
Это приводит к более надежному и поддерживаемому коду.