[cs] - DI

링딩·2023년 4월 24일
0

Computer Science

목록 보기
40/49




1. 다양한 의존관계 주입 방법

DI(Dependency Injection)란?

◽ 정의

DI란 의존성 주입이라 부르며, 객체를 직접 생성하는 게 아닌 외부(IOC 컨테이너)에서 생성한 후 주입시켜주는 방식이다.

의존성 주입 방식으로는 3가지 방법이 존재

  • 생성자 주입
  • 수정자 주입(setter 주입)
  • 필드 주입
  • 일반 메서드 주입

🎉 생성자 주입

  • 우리가 주로 진행한 방식임
  • 생성자 호출시점에 딱 1번만 호출되는 것이 보장
  • 불변, 필수 의존관계에 사용 (null 이나 비워두어선 안됨)
  • 생성자가 1개 밖에 없다면 @Autowired 생략해도 자동 주입이 가능.
@Component
public class OrderServiceImpl implements OrderService {
	private final MemberRepository memberRepository;
 	private final DiscountPolicy discountPolicy;
 	
    @Autowired
 	public OrderServiceImpl(MemberRepository memberRepository, DiscountPolicy 
discountPolicy) {
 		this.memberRepository = memberRepository;
 		this.discountPolicy = discountPolicy;
 	}
}

🎉 수정자 주입(setter주입)

  • 선택, 변경 가능성이 있는 의존관계에 사용
  • @Autowired의 기본동작은 주입 대상이 없다면 오류가 발생 -> @Autowired(required = false) 지정해주면 해결
@Component
public class OrderServiceImpl implements OrderService {
 	private MemberRepository memberRepository;
 	private DiscountPolicy discountPolicy;
 	
    @Autowired
 	public void setMemberRepository(MemberRepository memberRepository) {
 		this.memberRepository = memberRepository;
 	}
 	@Autowired
 	public void setDiscountPolicy(DiscountPolicy discountPolicy) {
 		this.discountPolicy = discountPolicy;
 	}
}

🎉 필드 주입

  • 코드는 간결, but 외부에서 변경이 불가능 => DI 프레임워크가 없으면 아무것도 할 수 없음.
  • 사용하지 말길...(굳이 쓴다면 테스트 코드)
@Autowired
private MemberRepository memberRepository;

@Autowired
private DiscountPolicy discountPolicy;

🎉 일반 메서드 주입 (잘 사용 x)

@Autowired
public void init(MemberRepository memberRepository, DiscountPolicy 
discountPolicy) {
	this.memberRepository = memberRepository;
 	this.discountPolicy = discountPolicy;
 }


+) 옵션처리

: 주입할 스프링 빈 없이도 동작해야 할 때가 있다. 그리고, @Autowired의 required=true라면 자동주입 대상이 없을 시 오류가 발생해버린다...

자동 주입 대상을 옵션으로 처리하는 방법

  • @Autowired(required = false)
    -> 수정자 메서드 자체가 호출 x , 주입할 대상이 없어도 동작 가능.
  • 매개변수에 @Nullable
    -> 호출은 되지만 자동 주입 대상이 없으면 null이 입력
  • Optional<>
    -> 자동 주입 대상이 없다면, Optional.empty 이 호출된다.

2. 생성자 주입을 추천

+) 의존성과 설정값을 생성자 인자로 주입해야 하는 이유에 대해 설명해주세요.

왜 추천할까?

1. 불변

  • 생성자 주입은 객체 생성 때 단 1번만 호출된다.
    =>즉, 종료 시점까지 의존관계가 변경되지 않으며 다시 호출될 일이 없다.

2. final

  • 오로지 생성자 주입만 사용 가능하며 값이 설정되지 않는 부분을 알려준다.
    => 컴파일 시점에 오류를 막을 수 있다.

3. 누락

  • 데이터를 누락 했을 때 컴파일 오류를 발생시킨다
  • IDE를 통해 어떤 값을 필수로 주입해야 하는지 알려준다.



DI의 장점

  • 의존성이 줄어든다. (변경에 덜 취약해진다.)
  • 모의 객체를 주입할 수 있기 때문에 단위 테스트가 쉬워진다.
  • 가독성이 높아진다.
  • 재사용성이 높아진다.




출처

ohzzi님의 글을 참고하여 작성하였습니다.

profile
초짜 백엔드 개린이

0개의 댓글