인프런 커뮤니티 질문&답변
@Primary를 쓴다는게 이해가 안되요
해결된 질문
작성
·
216
0
우선같은 타입의 빈이 등록됐을때
우선권을 주기 위해 @Primary를 쓰는건 알겠습니다.
근데 제가 이해가 안되는거는
같은 타입의 빈(A, B가있을 시) 2개중 1개인 A에
@Primary를 쓰게 된다면
결국은 A가 주입되는데우선권을 가지기 떄문에
어느곳에서든 B는 결국 안쓰게 되는거 아닌가요?
만약 B를 주입하기 위해서라면 주입받는곳에
@Qualifier를 설정해서 써야하는건지..
만약 @Qualifier를 쓰게 된다면 굳이 @Primary를 왜
쓰는지...
제 머리론 @Primary를 쓰는게 이해가 안됩니다..
퀴즈
What are the main reasons why Field Injection is generally not recommended?
Because it is difficult to guarantee immutability
Because changing dependencies is easy
Because it's difficult to test with pure Java code
Because writing configuration code is complex
답변 1
0
안녕하세요. 조윤호님, 공식 서포터즈 David입니다.
.
동일한 타입을 가지는 여러 가지의 빈을 만들어야 하는 상황이 있습니다.
예를 들자면 Alphabet이라는 인터페이스를 구현하는 A, B, C 클래스가 있습니다.
A, B, C 각각은 빈으로 등록되어 사용되고 있습니다.
그런데 어떤 빈은 Alphabet 구현체 중 일부만 의존관계로 주입받아야 합니다.
그 중 첫번째 알파벳은 무조건 A를 쓰기로 했습니다.
두번째 알파벳은 상황에 따라 변경될 수 있으므로 기본값(동일한 타입 중 @Primary로 지정된 빈)을 사용하기로 합니다.
constructor(@Qualifier("a") Alphabet alphabet1, Alphabet alphabet2)
이와 같은 상황에서 @Primary를 사용할 수 있습니다.
만약 @Primary를 사용하지 않는다면 변수명과 일치하는 빈을 찾겠지만 그런 빈은 없기 때문에 결국 여러 빈 중에 어떤 것을 사용할 것인지 몰라서 에러를 발생시킬 것입니다.
그러면 필요한 빈만 등록하면 되지 않느냐?라고 물으신다면
A, B, C 빈을 모두 필요로 하는 로직에서는 해당 빈들을 Map<Alphabet>으로 받아서 사용하는 로직이 있다면 위쪽 생성자 예시에서 들었듯 2개의 빈만 등록해서 사용하는 것은 어렵습니다.
.
감사합니다.






음 그럼 제가 이해한게 이게 맞는지 알려주시면 감사하겠습니다.
동일 타입의 빈 A,B,C 가 있고 모두 필요한 상태일 때
1. 기본적으로 주입되서 쓸 빈(위 답변처럼 B) B를 @Primary 로 지정
2. B를 제외한 다른 A,C를 주입받기 위해서는 @Qualifier로 주입 받음
결론
@Primary를 지정하지 않고 @Qualifier를 통해 동일 타입의 빈 중 필요한 빈을 주입받을 수 있다.
하지만 @Primary를 쓰는 이유는 편리상 + 동일 타입의 빈 중 주로 많이 쓰이는 빈을 @Primary를 지정해줘
불편함을 감소시키기 위함이다
라고 이해하면 될까요?