@Component는 구현체에만 붙인다?
1072
投稿した質問数 112
인터페이스에는 안붙이고 구현체에만 @Component를 붙이는 이유는뭔가요?
回答 2
2
안녕하세요. 김민지님, 공식 서포터즈 OMG입니다.
의존성 주입을 배울 때를 기억해보시면
MemberService memberService = new MemberService();
를
@Autowired
MemberService memberService;
위와 같이 스프링 컨테이너에 주입을 받는 것을 배웠던 기억이 있으실꺼에요.
new 연산자로 객체(인스턴스)를 생성할 수 있는 것은 "Class"입니다. "Interface"는 불가능합니다.
@Component의 역할을 생각해보면, @Component가 붙은 클래스를 스프링 컨테이너가 관리하는 Bean으로 등록을 하고, 해당 객체가 주입이 될 때 객체를 생성할 수 있어야합니다. 하지만 Interface의 경우 객체 생성이 불가능하므로 @Component가 붙어도 주입을 해줄 수 있는 역할 자체가 불가능합니다.
감사합니다.
0
저도 비슷한 의문이 잠시 들었는데, 그 이유가 "인터페이스가 아니라 구현체에 @Component를 붙인다면, 나중에 autowired해줄 때 해당 빈이 중복으로 찾아지지 않을까? 인터페이스면 유일할 텐데 구현체라 유일하지 못한 문제를 스프링은 어떻게 해결하는건가?"라는 의문이 들어서였는데요.
의존관계 자동주입 > 빈이 2개 이상 - 문제
라는 주제의 뒷부분 강의를 보니 의문이 해결되네요ㅎㅎ 수동 주입을 해줄 때 하나의 구현체를 결국 선택해야하듯이, @Component 어노테이션도 한 구현체를 선택해서 거기에만 붙여줘야하는군요.
코드 자료
0
27
2
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
0
51
2
MemberService의 인터페이스를 왜 사용하는지 궁금합니다.
0
74
1
롬복 @Setter를 써야 하는 상황이 있는건가요?
0
89
1
빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?
0
81
1
테스트 속도가 나중에 영향이 있을까요?
0
77
1
gradle 설정 안떠서 질문 남깁니다!
0
121
2
build.gradle로 프로젝트를 여는 이유
0
85
1
provider 사용하는 이유
0
88
1
다음 강의 뭘 들어야 할까요
0
126
2
프로토타입 빈, 직접 destroy 호출 안 할 경우
0
64
1
beanB
0
82
2
퀴즈다시풀기
0
66
1
Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ
0
92
2
"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.
0
66
3
run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>
0
105
2
도메인의 정의?
0
59
1
ApplicationContext 질문입니다.
0
62
1
@Scope의 proxyMode를 사용할때 단위 테스트 방법
0
88
2
ai api 선정하기 관련 질문
0
118
2
생성자 자동주입 관련해서
0
64
1
생성자 직접 호출 vs 팩토리 메서드 패턴
0
96
2
Spring에서 SessionScope와 RequestScope는 함께 사용되나요?
1
65
1
12:25
0
77
2

