기본 콘텐츠로 건너뛰기

[Spring] DI 1탄 - DI개요

DI(Dependency Injection)란 무엇인가?

기능을 실행하기 위해 다른 클래스를 필요로 할 때 이를 의존한다 한다.


public class UserServiceImpl implements UserService {
      private final UserRepository userRepository;
      private final PasswordEncoder passwordEncoder;

      public UserServiceImpl(DataSource dataSource) {
          this.userRepository = new JdbcUserRepository(dataSource);
          this.passwordEncoder = new BCryptPasswordEncoder();
      }
      @Override
      public void register(User user, String rawPassword) {

      }
}


생성자에서 위와 같이 초기화를 직접 할당하게 되면 '클래스간 결합도가 높다'라는 문제가
발생한다. 이는 UserServiceImple을 개발하는 단계에서 의존하는 컴포넌트 클래스가
완성되어 있어야 한다는 의미다.


의존하는 클래스가 아직 개발중이거나 미완성이라면 완벽한 컴포넌트를 구성할 수가 없게 된다.


이런 결합도를 낮추려면 생성자에서 직접생성 대신 생성자의 인수로 받아 할당하는 방법이 있다.
 
public UserServiceImpl(UserRepository userRepository, PasswordEncoder passwordEncoder) {
      this.userRepository = userRepository;
      this.passwordEncoder = passwordEncoder;
}


어떤 클래스가 필요로 하는 컴포넌트를 외부에서 생성한 후, 내부에서 사용 가능하게 만들어주는
과정을 '의존성 주입(DI)'이라 한다.
이런 의존성 주입을 자동으로 처리하는 기반을
'DI컨테이너(=스프링컨테이너 = IoC컨테이너 = 빈컨테이너)'라고 한다.
인스턴스의 스코프 관리도 'DI 컨테이너'가 대신해준다.


DI는 IoC라는 디자인 패턴 중 하나다. 컴포넌트를 구성하는 인스턴스의 생성과 의존 관계의
연결 처리를 해당 소스코드가 아닌 DI컨테이너(IoC 컨테이너)에서 대신하기 때문에 제어가
역전 됬다고 한다.


DI에 의존 객체를 전달하는 방법

크게 생성자 방식과 프로퍼티 설정 방식이 있다. 생성자 방식은 앞에서 예제에 봤고, 프로퍼티 방식을
보면, 객체를 전달 받기 위해 매서드(세터메서드)를 이용한다. setXXX.


DI 컨테이너란 무엇인가?

스프링은 객체를 생성하고 객체를 연결해주는 조립기 역할을 한다.
조립기 기능을 하는 클래스중 하나의 예로 GenericXmlApplicationContex가 있다.
조립기 클래스는 xml등의 정의된 설정 정보를 읽어와 객체를 생성, 연결한 뒤 내부적으로 보관한다.
이런 생성과 보관 떄문에 스프링을 ‘객체 컨테이너’라고도 부른다.
스프링 컨테이너가 생성해 보관하는 객체를 스프링 빈 객체라 부른다.

지금까지 DI에 관해서 간략하게 알아보았다.
프로그램이건 어떤 학문을 배울 땐 용어가 가장 중요한거 같다. 앞으로 중요한 용어에 대해선 노란색으로 색칠해 놓을 테니 이해가 부족하다면 다른 참고자료들을 활용해 꼭 숙지하도록 하자.

댓글

이 블로그의 인기 게시물

[스프링부트2.0 낚시게시판] 01. 프로젝트 생성 및 환경을 세팅해 보자

첫번째. 이클립스에서 프로젝트를 생성해 보자. 빠밤! 1. 이클립스 실행하고 프로젝트 생성하기  - 이클립스 실행 후 File -> New -> Spring Starter Project클릭 ( 부트는 Spring Starter Project로!! )        해당 프로젝트 설정을 본인의 입맛에 맞게? 해주자. 처음엔 저와 똑같이 하는게 삽질(?)의 노고를 덜 수 있으니 저 같은 초보 개발자 분들이나 이제 막 공부를 시작 하셧다면 위와 가이 설정 하는걸 추천.  - New Spring Starter Project Dependencies    - Spring Boot Version : 2.0.2    - Core : DevTools, Security, Lombok 클릭    - Web : web  클릭    - SQL : JPA, H2 클릭    - template Engines : Mstache   --> 타임리프(요즘 회사에서 많이 쓴다고해서)   - 그다음 다음 -> Finish 클릭하게 되면 Maven에 관한 프로젝트가 생성된다.   처음엔 메이븐 디펜던시부분을 받느라 시간이 걸릴수 있다. 프로젝트 구조는 스프링과 별반 차이가 없어 보인다 프로젝트 구조 관련해선 조만간 포스팅 해봐야 겠다. (요즘 책 읽을 시간도 없어서...😂) 두번째. 실행을 해보자.  스프링 부트2.0의 특징은 자체적으로 톰켓이 내장 되어 있어 따로 톰켓을 설정하는 부분이 없어서 아주 매우 편안하게 되었다.    - 실행은 src/main/java 밑에 com.fishing.board 패키지 밑에 FishBoardApplication.java 오른쪽 클릭 후...

[SpringBoot] Spring Data JPA를 알아보자 [2탄 엔티티를 다루기]

이번 시간에는 엔티티 클래스 설계서 부터 테스트까지 진행해 보도록 하겠다. 1. 엔티티 클래스 설계   - JPA는 자동으로 테이블을 생성하는 기능을 가질 수 있다. 다음 2가지 방법이 있다.     1) SQL을 이용해 테이블을 먼저 생성하고 엔티티 클래스를 만드는 방법     2) JPA를 이용해 클래스만 설계하고 자동으로 테이블을 생성하는 방법   - 이중에서 2)번 방법을 알아보자.   - JPA 엔티티 클래스를 생성하는 작업은 다음 과정을 거친다     1) 클래스 설계     2) 각종 애너테이션을 이용해 제약 조건 추가 설정     3) 엔티티 간 연관관계 설정 1.1 엔티티 클래스 설계    package com . example . sutdy . domain ; import lombok.Getter ; import lombok.Setter ; import lombok.ToString ; import java.sql.Timestamp ; @Getter @Setter @ToString public class Board { private Long bno; private String title; private String writer; private String content; private Timestamp regdate; private Timestamp updatedate; }   - 위와 같이 일반적인 방법으로 클래스를 만들어 봤다. 다음 JPA 어노테이션에 관해 알아보고 붙여보자 1.1.2 JPA 어노테이션   - @Id : 각 엔티티를 구별할수 있도록 식별 ID부과.(일종의 primary key로 보면된다). 모든 엔티티에 반드시 지정하자.   - @Column : 인스턴스 ...

[Java] JVM에 대해 알아보자

이번 시간엔는 JVM에 대해 전반적으로 알아보려 한다. 자바 코드를 작성하는 일에 JVM이 뭐 구지 중요한가 의심이 가지만, 성능 튜닝이나 더 아름다운 코드를 작성하기 위해 어느 정도 이해가 필요한것 같다. JVM을 알아보면서 추가적으로 필요한 개념을 더 설명하려한다. 자 그럼 시작 해보자. <JVM 그림> <Runtime Data Access> JVM - 자바의 특징 중 Write once, run everywhere가 있다. JVM이 OS와 프로그램의 매개체 역할을 하고, 애플리케이션은 JVM 위에서 동작하도록 설계 되었다. - 작성된 자바프로그램의 바이트 코드를 실행할 수 있는 주체이다. - 스택기반의 가상머신이다. - 가비지 컬렉션을 실행한다. (가비지컬렉터 이용) - Java 애플리케이션은 플랫폼에 독립적이다. 하지만 JVM은 플랫폼에 종속적이다. 각 플랫폼(OS)마다 다르게 구현되어야 한다. JVM 구조 JVM의 내부 구조를 큰 형태로 보면 클래스 로더 서브시스템, 런타임 데이터 영역 (Runtime Data Area) 그리고 실행엔진(Execution Engine)으로 나눌 수 있다. Class Loader : JVM 내로 class를 로드하고 Link를 통해 적절히 배치하는 일련의 작업을 수행하는 모듈. Runtime시 동적으로 수행된다. 클래스를 분석하는 과정에서 리플렉션 기법을 사용해 컴파일 된 클래스의 내부를 분석한다. Execution Engine : class loader를 통해 JVM 내의 런타임 데이터 영역에 배치된 바이트 코드는 실행 엔진에 의해 실행된다. 실행 엔진은 자바 바이트 코드를 명령어 단위로 읽어 실행한다. Garbage Collector : 가비지 컬렉터를 통해 자동화된 메모리 관리 기능을 제공한다. Garbage Collector는 Garbage Collection을 수행하는 모듈 쓰레드를 말한다....