스프링 컨테이너가 생성되는 과정을 알아보자
ApplicationContext applicationContext =new AnnotationConfigApplicationContext(AppConfig.class);
ApplicationContext : 스프링 컨테이너, 인터페이스이다.
스프링 컨테이너는 XML을 기반으로 만들 수 있고, 애노테이션 기반의 자바 설정 클래스로 만들 수 있다.
최근에는 XML기반으로 작성을 하지 않음.
스프링 컨테이너를 부를 때 'BeanFactory', 'ApplicationContext'로 구분해서 이야기한다
'BeanFactory'를 직접 사용하는 경우는 없으므로 'ApplicationContext'를 스프링 컨테이너라 한다
new AnnotationConfigApplicationContext(AppConfig.class);
-> Appconfig의 정보를 주면 스프링 컨테이너가 만들어 진다
스프링 컨테이너 안에는 스프링 빈 저장소라는 것이 있다.
키는 빈의 이름 값은 빈 객체가 된다
스프링 컨테이너를 생성할 때는 구성 정보(AppConfig)를 지정해주어야 한다.
스프링 컨테이너가 AppConfig.class 정보를 보고 객체 생성해야 할 것을 인지한다.
소스코드에 @Bean이 붙은 것들을 모두 호출해 준다
메서드 이름을 빈의 이름으로 지정하고, 반환하는 객체를 빈 객체로 지정한다.
빈 이름은 직접 부여할 수 도 있다
@Bean(name="memoService2")
주의 : 빈 이름은 항상 다른 이름을 부여해야 한다.
코드를 보면 MemberServiceImpl은 의존관계로 memberRepository를 넣어줬다
OrderServiceImpl은 memberRepository도 의존하고 discountPolicy도 의존한다
스프링 컨테이너는 설정 정보를 참고해서 의존관계를 주입(DI)한다.
스프링은 빈을 생성하고, 의존관계를 주입하는 단계가 나누어져있다.
자바 코드로 스프링 빈을 등록하면 생성자를 호출하면서 의존관계 주입도 한번에 처리된다.
부모 타입으로 조회하면, 자식 타입도 함께 조회한다.
그래서 모든 자바 객체의 최고 부모인 'Object'타입으로 조회하면, 모든 스프링 빈을 조회한다.
스프링 컨테이너의 최상위 인터페이스다.
스프링 빈을 관리하고 조회하는 역할을 담당한다
BeanFactory 기능을 모두 상속받아서 제공한다.
빈을 관리하고 검색하는 기능을 BeanFactory가 제공해주는데, 그 둘의 차이는 뭘까?
애플리케이션을 개발할 때는 빈은 관리하고 조회하는 기능은 물론이고, 수 많은 부가기능이 필요하다.
ApplicationContext는 BeanFactory의 기능을 상속받는다
ApplicationContext는 빈 관리기능 + 편리한 부가 기능을 제공한다
BeanFactory를 직접 사용할 일은 거의 없다. 부가 기능이 포함된 ApplicationContext를 사용
BeanFactory나 Application를 스프링 컨테이너라 한다