일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 어떻게 나답게 살 것인가
- T자형인재
- 자취필수템
- 면접
- 소프시스
- 함수형 프로그래밍
- 베드트레이
- 1일1커밋
- 북한살둘레길
- 한달브런치북만들기
- 한단어의힘
- 소프시스 밤부 좌식 엑슬 테이블
- 브런치작가되기
- 목적중심리더십
- 프래그먼트
- 좌식테이블
- 슬기로운 온라인 게임
- 베드테이블
- 안드로이드
- 지지않는다는말
- 한달독서
- 재택근무
- 목적 중심 리더십
- 커스텀린트
- 아비투스
- 한달어스
- 캐치마인드
- 리얼하다
- 테트리스
- 끝말잇기
- Today
- Total
정상에서 IT를 외치다
[Android, Dagger2] DI 기본 개념과 Dagger2 사용 예제 - 놈!놈!놈! 본문
안드로이드 DI 와 Dagger2 에 관한 포스팅을 해보겠습니다.
설명은 굉장히 짧게! 이해는 아주 잘 되게!
DI 란?
DI 는 Dependency Injection 의 약자로 의존성 주입을 의미합니다. 특정 객체의 인스턴스가 필요한 경우 이를 외부에서 생성하여 전달하는 기법입니다.
Dagger 란?
안드로이드에서 의존성 주입을 구현하기 위해 사용하는 라이브러리 입니다.
사용하는 예제는 '김태호 - 커니의 코틀린' 에서 가져왔습니다.
햄버거 만들기
햄버거(Burger)를 만들어 보겠습니다.
햄버거는 밀빵(WheatBun) 과 소고기 패티(BeefPatty) 로 이루어져 있습니다.
햄버거
public class Burger {
public WheatBun bun;
public BeefPatty patty;
public Burger(WheatBun bun, BeefPatty patty) {
this.bun = bun;
this.patty = patty;
}
}
햄버거를 만들기 위한 밀빵(WheatBun) 과 소고기 패티(BeefPatty) 를 준비해 봤습니다.
밀빵
public class WheatBun {
public String getBun() {
return "밀빵";
}
}
소고기 패티
public class BeefPatty {
public String getPatty() {
return "소고기 패티";
}
}
그러면 우리의 MainActivity 에서 햄버거를 만들려면 어떻게 해야 할까요?
public class MainActivity extends AppCompatActivity {
Burger burger;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
WheatBun bun = new WheatBun();
BeefPatty patty = new BeefPatty();
burger = new Burger(bun, patty);
}
}
이렇게 new 오퍼레이터를 사용해서 밀빵과 소고기 패티를 가져와서 햄버거를 만듭니다.
이렇게 MainActivity 에서 인스턴트를 생성하는게 기존의 방식이었습니다. 여기에 의존성 주입을 사용하면 new 오퍼레이터 사용 없이 외부에서 자동으로 객체를 생성해 줍니다.
Dagger2 적용하기
0. App 버전의 build.gradle 에 라이브러리 추가하기
implementation "com.google.dagger:dagger:$daggerVersion"
implementation "com.google.dagger:dagger-android:$daggerVersion"
implementation "com.google.dagger:dagger-android-support:$daggerVersion"
kapt "com.google.dagger:dagger-android-processor:$daggerVersion"
kapt "com.google.dagger:dagger-compiler:$daggerVersion"
제가 사용한 버전은 2.12 입니다. 대거 최신 버전은 문서를 확인해 주세요.
1. Module 과 Component 를 만들어야 합니다.
Module 은 필요한 객체를 제공하는 역활을 합니다.
우리가 MainActivity 에서 아래와 같이 객체를 생성했죠?
WheatBun bun = new WheatBun();
BeefPatty patty = new BeefPatty();
Burger burger = new Burger(bun, patty);
이걸 Module 이 해줍니다.
@Module
public class BurgerModule {
@Provides
Burger provideBurger(WheatBun bun, BeefPatty patty) {
return new Burger(bun, patty);
}
@Provides
WheatBun provideBun() {
return new WheatBun();
}
@Provides
BeefPatty providePatty() {
return new BeefPatty();
}
}
생성할 객체를 @Provides 어노테이션을 사용해서 생성해 줍니다.
Component 는 모듈에서 제공받은 객체를 조합하여 필요한 곳에 주입하는 역활을 합니다.
@Component(modules = BurgerModule.class)
public interface BurgerComponent {
void inject(MainActivity activity);
}
@Componet 어노테이션을 통해 BurgerModule.class 를 가져왔습니다. 이를 inject() 함수를 통해 MainActivity 에 주입했습니다. ( void inject() 의 함수 명은 정해진 값이 아닌 임의의 함수 명을 정해주시면 됩니다. )
2. MainActivity 에서 사용해보기
1번 작업을 한 후 프로젝트를 빌드 해 주시면 Dagger + {ComponetName} 파일이 자동 생성됩니다.
(여기서는 DaggerBurgerComponent 가 생성됩니다. 이렇게 컴파일 단계에서 의존성을 체크할 수 있어 앱의 안정성을 높여줄 수 있습니다.)
public class MainActivity extends AppCompatActivity {
@Inject
Burger burger;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
/*WheatBun bun = new WheatBun();
BeefPatty patty = new BeefPatty();
burger = new Burger(bun, patty);*/
BurgerComponent component = DaggerBurgerComponent.builder()
.burgerModule(new BurgerModule())
.build();
component.inject(this);
Log.d("MyTag","burger bun : " + burger.bun.getBun() +" , patty : " + burger.patty.getPatty());
}
}
짜짠! 위와같이 new 오퍼레이터 사용 없이 위와 같은 코드로 burger 객체를 외부에서 생성하여 가져올 수 있습니다.
(burger = new Burger() 를 안했는데도 객체가 생성되었어요!! 놀라워라!!)
이름 그림으로 도식화 하여 이해하기 쉽게 표현해 보겠습니다.
간단히 공급하는 놈(Module)과 주입받는 놈(Inject)
그리고 이 사이를 연결해주는 놈(Component)로 이해하시면 됩니다. 놈!놈!놈!
Module
Module 에서 공급할 객체를 생성합니다. (예제에서는 햄거거, 밀빵, 소고기 패티를 생성했습니다.)
Component
Component 에서는 Module을 불러오고 어디로 주입할 지를 정합니다. (MainActivity 주입할 겁니다!)
Inject
@Inject 어노테이션을 통해 주입받는 놈들 가져옵니다.
(MainActivity 에서 @inject Burger burger 변수를 선언했더니 객체가 두둥! 생성!)
기존의 객체 생성 방식보다는 코드가 좀 더 많고 복잡해 보이죠? 하지만!! 원리를 알고 사용하다보면 훨씬 좋은 점이 많다고 합니다. (저도 아직 배우는 중이라...아직은 모르겠지만 계속 써볼려고 합니다). 다음 포스팅에서는 이를 안드로이드에서 어떻게 활용하면 좋을지 또 어떤 점이 Dagger2 의 장점인지에 관해 포스팅 해보겠습니다. 그럼 안뇨옹~!
<참고자료>
저는 짧게 설명했지만 DI 와 Dagger2 의 구체적인 개념 설명은 링크1, 링크2에 잘 정리 되어있습니다.
꼭! 읽어 보시길 추천 드립니다.
또 다른 쉬운 예제를 보고 싶다면 쉬운 Dagger2
심화 자료를 원한다면 Dagger2 학습에 필요한 자료
'안드로이드' 카테고리의 다른 글
[Android, Dagger2] Dagger2 사용 예제 - 2. SharedPref (0) | 2018.10.04 |
---|---|
[Android, Dagger2] Dagger2 사용 예제 - 1 (0) | 2018.10.04 |
[Android, ItemDecoration] 리사이클러뷰에 아이템데코레이션 사용하기 (2) | 2018.09.19 |
[Android, RecyclerView] 리사이클러뷰 레이아웃 매니저 종류 (2) | 2018.09.18 |
[Android, RecyclerView] 리사이클러 뷰 만들기 (12) | 2018.09.18 |