티스토리 뷰

1. DI 란?

- 생성자에 @Autowired 가 있으면 스프링이 연관된 객체를 스프링 컨테이너에서 찾아서 넣어준다.

- 이렇게 객체 의존관계를 외부에서 넣어주는 것을 DI (Dependency Injection), 의존성 주입이라 한다.

- DI에는 필드 주입setter 주입생성자 주입 이렇게 3가지 방법이 있다. 의존관계가 실행중에 동적으로 변하는 경우는 거의 없으므로 생성자 주입을 권장한다.

 

Question

생성자 주입을 권장하는 이유는 무엇인가요?

Answer

1. 순환 참조 방지

필드 주입이나 수정자 주입으로 DI할 경우 참조순환이 발생할 수 있다. 이는 실제로 메소드를 실행하기 전까지는 에러가 나는지 알 수 없다.

하지만, 생성자 주입을 통하여 DI할 경우 어플리케이션 실행단계에서 순환참조를 발견하여 error가 발생한다.

2. final 선언 가능

필드 주입이나 수정자 주입은 final로 선언할 수 없다. 즉, 나중에 변경될 수 있다.

하지만, 생성자 주입은 final로 선언할 수 있다. 즉, 런타임에 객체 불변성을 보장한다.

3. 테스트 코드 작성이 용이하다.

 


 

2. Spring Bean을 등록하는 2가지 방법

  1. 컴포넌트 스캔과 자동 의존관계 설정
  2. 자바코드로 직접 등록

 

방법 1. 컴포넌트 스캔과 자동 의존관계 설정

- @Component 어노테이션이 있으면 Spring Bean으로 자동 등록된다.

- @Controller, @Service, @Repository 모두 @Component를 포함하고 있으므로 Spring Bean으로 등록된다.

@Controller의 내부. @Component를 가지고 있는것을 확인할 수 있다.

Question

어? 그럼 아무데나 @Service 붙이면 Bean으로 등록할 수 있는건가용?

Answer

NO!! SpringApplication이 위치한 패키지 하위에 있어야 스캔이 가능하다.

@SpringBootApplication 을 열어본 결과. @ComponentScan을 가지고 있는것을 확인할 수 있다.

 

참고

스프링은 스프링 컨테이너에 스프링 빈을 등록할 때, 기본으로 싱글톤으로 등록한다(유일하게 하나만 등록해서 공유한다) 따라서 같은 스프링 빈이면 모두 같은 인스턴스다. 설정으로 싱글톤이 아니게 설정할 수 있지만, 특별한 경우를 제외하면 대부분 싱글톤을 사용한다.

 

방법 2. 자바 코드로 직접 Spring Bean 등록하기

- Config클래스를 생성한다. @Configration 어노테이션을 붙여야함

- @Bean 어노테이션으로 객체를 Bean으로 등록한다.

Controller는 어쩔수없이 @Controller를 써야한다.

Question

아니.. @Service, @Repository가 훨씬 빠르고 간단하구만 Config 클래스를 만드는건 쓸모없는거 아니에용? 

Answer

NO!! @Service, @Repository로 Bean을 등록할 경우 나중에 Repository의 구현체를 바꿀 경우 관련된 모든 클래스를 고쳐야한다.

반면에 Config 클래스로 Bean을 등록하면 나중에 return 객체만 바꾸면 끝이다. 즉, 유지보수가 더 편해져요~

 


 

참고

- XML로 설정하는 방식도 있지만 최근에는 잘 사용하지 않으므로 생략한다.

- DI에는 필드 주입, setter 주입, 생성자 주입 이렇게 3가지 방법이 있다. 의존관계가 실행중에 동적으로 변하는 경우는 거의 없으므로 생성자 주입을 권장한다.

- 실무에서는 주로 정형화된 컨트롤러, 서비스, 리포지토리 같은 코드는 컴포넌트 스캔을 사용한다. 그리고 정형화 되지 않거나, 상황에 따라 구현 클래스를 변경해야 하면 설정을 통해 스프링 빈으로 등록한다.

- @Autowired 를 통한 DI는 helloConroller , memberService 등과 같이 스프링이 관리하는 객체에서만 동작한다. 스프링 빈으로 등록하지 않고 내가 직접 생성한 객체에서는 동작하지 않는다.

공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/05   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함