강의

멘토링

로드맵

인프런 커뮤니티 질문&답변

조윤호님의 프로필 이미지
조윤호

작성한 질문수

스프링 핵심 원리 - 기본편

@Autowired 필드 명, @Qualifier, @Primary

@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를 지정해줘

불편함을 감소시키기 위함이다

 

라고 이해하면 될까요?

네, 적어도 제가 이해하고 있는 부분에서는 그렇습니다.

조윤호님의 프로필 이미지
조윤호
질문자

답변 감사드립니다^^

조윤호님의 프로필 이미지
조윤호

작성한 질문수

질문하기