컴포넌트 스캔과 자동 의존관계 설정
component관련 annotation이 있으면 객체를 생성해서 스프링 컨테이너에 등록
→ 단, 실행하려는 Application이 있는 패키지의 하위에 있는 것들만 스프링 빈으로 등록
@Controller, @Service, @Repository안에 @Component가 포함되어 있으므로 스프링빈으로 자동 등록된다
@Controller
@Service
@Repository
ex)
스프링이 뜰때 스프링 컨테이너가 생김
→ @Controller
: 컨트롤러 객체를 생성해서 스프링 컨테이너에 넣어주고 관리
→ 스프링빈
이 관리된다고 표현함
@Autowired
: 스프링이 연관된 객체를 스프링 컨테이너에서 찾아서 넣어줌
→ 객체 의존관계를 외부에서 넣어주는 것을 DI(의존성 주입)이라고 함
즉, autowired는 연관관계를 등록
memberController : @Controller
→ 생성자에 memberService
→ memberService : @Service
→ 생성자에 memberRepository
→ memberRepository : @Repository
참고 : 스프링은 스프링 컨테이너에 스프링 빈을 등록할때, 기본적으로 싱글톤으로 등록한다.
→ 따라서 같은 스프링빈이면 모두 같은 인스턴스이다.
설정으로 싱글톤이 아니게 설정할 수 있지만 특별한 경우 아니면 사용 X
자바 코드로 직접 스프링 빈 등록하기
memberService와 memoryMemberRepository를 스프링빈에 등록해줌
controller는 어쩔 수 없음, autowired로 memberService와 연결해주기
package hello.hellospring.service;
import hello.hellospring.repository.MemberRepository;
import hello.hellospring.repository.MemoryMemberRepository;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class SpringConfig {
@Bean
public MemberService memberService(){
// memberRepository와 의존관계연결
return new MemberService(memberRepository());
}
@Bean
public MemberRepository memberRepository(){
return new MemoryMemberRepository();
}
}
참고 : DI에는 필드 주입, setter 주입, 생성자 주입 3가지 방법이 있다.
→ 의존관계가 실행중에 동적으로 변하는 경우는 거의 없으므로 생성자 주입을 권장
참고: 실무에서는 주로 정형화된 컨트롤러, 서비스, 리포지토리 같은 코드는 컴포넌트 스캔을 사용한다.
→ 정형화 되지 않거나, 상황에 따라 구현 클래스를 변경해야 하면 설정을 통해 스프링 빈으로 등록한다.
ex) 아직 데이터 저장소가 결정되지 않은 경우
주의: @Autowired 를 통한 DI는 helloController , memberService 등과 같이 스프링이 관리하는 객체에서만 동작한다.
스프링 빈으로 등록하지 않고 내가 직접 생성한 객체에서는 동작하지 않는다.
인프런 스프링 입문 - 김영한 강의를 듣고 정리한 내용입니다