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

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

작성한 질문수

스프링 핵심 원리 - 기본편

@Autowired 필드 명, @Qualifier, @Primary

@Primary를 쓴다는게 이해가 안되요

해결된 질문

작성

·

175

0

우선같은 타입의 빈이 등록됐을때

우선권을 주기 위해 @Primary를 쓰는건 알겠습니다.

 

근데 제가 이해가 안되는거는

 

같은 타입의 빈(A, B가있을 시) 2개중 1개인 A에 

@Primary를 쓰게 된다면

결국은  A가 주입되는데우선권을 가지기 떄문에

어느곳에서든 B는 결국 안쓰게 되는거 아닌가요?

 

만약 B를 주입하기 위해서라면 주입받는곳에

@Qualifier를 설정해서 써야하는건지..

만약 @Qualifier를 쓰게 된다면 굳이 @Primary를 왜

쓰는지...

 

 

제 머리론 @Primary를 쓰는게 이해가 안됩니다..

 

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

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

 

라고 이해하면 될까요?

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

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

답변 감사드립니다^^

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

작성한 질문수

질문하기