일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- web
- C++
- 코드업
- 리덕스장바구니
- js to ts
- 일상
- memory
- 스프링
- 백준
- 프로그래머스
- error
- react-redux
- 기초100제
- 자료구조
- codeup
- Operating System
- 분할메모리할당
- 정렬
- Java
- 토이프로젝트
- 알고리즘
- 협업
- 타입스크립트
- Spring
- Redux
- 파이썬
- CPU 스케줄링
- OS
- react
- 공부
- Today
- Total
감자튀김 공장🍟
[Spring] Dependency Injection(DI)란? 본문
1. Dependency Injection(의존성 주입) 이란?
DI는 기본적으로 객체가 필요로하는 객체(의존성)를 스스로 구성하게 하는 대신 제공하는 것이다. 의존성을
하거나 스텁할 수 있기 때문에 테스트에 매우 유용한 기술이다. 더 간단하게 풀어보자면 두 객체 간의 결합도를 낮추기 위해 객체 사이에 인터페이스를 놓아 의존 관계가 고정되지 않도록 하는 것이다.
2. Dependency Injection이 필요한 이유
public class MyPet {
private PetType pet;
public MyPet() {
this.pet = new Cat();
}
}
PetType객체에는 Cat과 Dog이 있다고 가정한다.
위의 코드와 같은 경우에 MyPet객체는 PetType을 의존하고 있음을 알 수 있다(정확히 말하자면 Cat을).
이런 경우에 아래와 같은 문제점들이 나타난다.
- MyPet객체가 PetType에 의존하고 있으며
- MyPet객체가 PetType의 생성을 제어하며
- PetType객체의 변화가 MyPet겍체의 변화까지 이끌어낸다.
MyPet에 Cat뿐만 아니라 Dog, Bird등의 객체들이 추가될때마다 계속해서 MyPet 생성자에 변경이 필요하며 이를 유연성이 떨어진다고 본다.
따라서 우리는 MyPet과 PetType의 결합도를 낮춰야한다. 이를 위해서 외부에서 의존성을 주입(Injection)해야한다.
3. Dependency Injection 하기
먼저 여러 동물들이 더 MyPet에 추가될 수 있기 때문에 여러 동물들을 PetType이라는 Interface로 설정한다.
public interface PetType {
}
public class Cat implements PetType {
}
이제 결합도를 낮추고(제거하고) 외부에서 의존성을 주입하면 아래와 같은 코드가 된다.
public class MyPet{
public PetType pet;
public MyPet(PetType pet) {
this.pet = pet;
}
}
여기서 Spring이 DI 컨테이너를 필요로 하는 이유를 알 수 있는데, 우선 MyPet에서 PetType 객체를 주입하기 위해서는 애플리케이션 실행 시점에 필요한 객체(빈)를 생성해야 하며, 의존성이 있는 두 객체를 연결하기 위해 한 객체를 다른 객체로 주입시켜야 하기 때문이다.
예를 들어 다음과 같이 Cat이라는 객체를 만들고, 그 객체를 PetType로 주입시켜주는 역할을 위해 DI 컨테이너가 필요하게 된 것이다.
public class BeanFactory {
public void store() {
// Bean의 생성
PetType Cat = new Cat();
// 의존성 주입
PetType pet = new PetType(Cat);
}
}
그리고 이러한 개념은 제어의 역전(Inversion of Control, IoC)라고 불리기도 한다. 어떠한 객체를 사용할지에 대한 책임이 BeanFactory와 같은 클래스에게 넘어갔고, 자신은 수동적으로 주입받는 객체를 사용하기 때문이다. (실제 Spring에서는 BeanFactory를 확장한 Application Context를 사용한다.)
4. DI의 장점
- 변경에 취약하지 않다.
- 컴포넌츠의 의존성이 줄어들면 변화에 덜 취약하다(코드 변경이 덜 까다로워 진다.)
- 코드의 재사용화가 가능하다.
- 일부 인터페이스의 다른 구현이 다른 부분에서 필요하다면 필요한 구성 요소는 해당 구현과 함께 작동하도록 구현해야 한다. 즉, 코드를 변경할 필요가 없다.
- 객제 생성과 분리된 사용이 가능하다.
참고 자료
https://effortguy.tistory.com/141
http://blog.gtiwari333.com/2011/05/understanding-dependency-injection-and.html
https://mangkyu.tistory.com/150
'JAVA > Spring' 카테고리의 다른 글
[Spring] java.lang.UnsupportedClassVersionError (0) | 2022.07.01 |
---|---|
[Spring] MVC 패턴 알아보기 (0) | 2022.04.19 |
[Spring] Aspect Oriented Programming (AOP)이란? (0) | 2022.04.18 |
[Spring] Spring 개요 (0) | 2022.04.15 |