아직은 개린이

[iOS 아키텍처 패턴] MVP 본문

Swift + iOS/iOS

[iOS 아키텍처 패턴] MVP

jiyeonlab 2020. 2. 28. 18:28

앞선 글에서 좋은 아키텍처란 무엇인지와 MVC 패턴에 대해 살펴보았다.

이번 글에서는 새롭게 공부하는 주제인 MVP 패턴에 대해 알아보고자 한다.

 


MVP

MVP 패턴의 다이어그램은 아래와 같다.

 

MVC 패턴과 굉장히 유사한 구조로 이루어져있지만, MVC는 아니다!

우선 MVC와 달리 UIViewUIViewControllerPassive View에 속해있다.

따라서, Controller에 해당하는 Presenter에는 View의 레이아웃과 관련된 코드와 View의 Life Cycle을 다루는 코드가 들어가지 않는다. 대신 ViewModel중재자 역할에 더 집중하여 View의 데이터와 상태 변화를 갱신하는 역할만을 수행한다.

이로 인해 각 객체의 독립성이 높이졌고, 테스트가 용이해졌다.

 

하지만, 뷰를 갱신하기 위한 메소드를 직접 작성한다던지 각 이벤트에 따른 메소드들을 바인딩해줘야 하는 등의 이유로 개발 비용이 MVC보다는 높아진다.

 

그렇다면, MVP좋은 아키텍처 3요소에 매칭해보자.

 

  • Distribution - PresenterModel은 거의 독립되어있고, View는 단순 출력만 하는 역할을 한다.
  • Testability - excellent하다. View의 재사용성 덕분에 각 요소의 테스트가 가능해졌다.
  • Ease of use - MVC보다 코드 양은 늘어나지만, MVC보다 각 요소들의 역할이 명확해졌다.

이제 MVP 패턴에 대해서 이론적으로는 제대로 알게 되었으니,

코드로 직접 적용해보는 연습을 해야겠다!!

 


참고 : https://medium.com/ios-os-x-development/ios-architecture-patterns-ecba4c38de52