디자인패턴
"디자인 패턴은 소프트웨어를 개발할 때 발생하는 다양한 문제에 대한 재사용 가능한 템플릿 해결방법!"
즉, 어떤 실질적인 코드가 아닌 아이디어라고 할 수 있다.
- 패턴 이름
- 해결할 문제, 해결 방법, 결과를 설명, 해당 디자인을 설명하고 공유하기 편하기 때문
- 해결할 문제
- 해당 패턴이 어떤 문제를 해결할 때 사용할 것인지
- 해결 방법
- 디자인 패턴은 다양한 상황에 적용될 수 있는 템플릿과 같기 때문에 해결 방법은 특정 디자인이나 구현을 설명하지는 않고, 추상적인 설명과 요소를 제공하여 해결 방법을 제시
- 결과
- 소프트웨어에서는 동일한 기능을 구현할 때 메모리, 속도 등을 비교하여 어느 코드가 더 나은 성능을 보이는지 비교할 수 있다. 또한 디자인 패턴을 사용하는 이유인 재사용성도 평가 항목에 포함된다.
디자인패턴의 종류
목적
패턴이 무엇을 하는지 정의하는 것으로 "생성", "구조", "행위" 중의 한 가지 목적을 갖는다.
- 구조 디자인 패턴 (Structural Design Pattern)ex) MVC, MVVM
- → 클래스나 객체의 구성을 통해 더 큰 구조로 만들 수 있게 해주는 것과 관련된 패턴
- 행위 디자인 패턴 (Behavioral Design Pattern)ex) Delegation, Observer
- → 패턴을 주로 클래스에 적용하는지 아니면 객체에 적용하는지에 따라 구분되는 패턴
- 생성 디자인 패턴 (Creational Design Pattern)ex) Singleton, Prototype
- → 객체의 생성과정에 관여하는 패턴
디자인패턴의 장단점
장점
- 개발자의 시간을 아껴주고 불필요한 작업방지
- 프로그램 시작시, 구체화하는데 최초 시작점이 된다.
- 디자인패턴은 개발자들의 언어 → 소통시 디자인패턴기반 의사소통
- 코드간의 반복성을 찾기 쉽도록 구현
단점
- 남용하면 프로젝트가 지나치게 복잡해질 수 있다. → 디자인패턴을 추가하기전에 문제를 정확히 정의해서 예방
- 디자인패턴을 많이 안다고 중요한 것이 아니다.
여러 디자인 패턴들
- 싱글턴 패턴 (Singleton Pattern)목적 : 생성범위 : 객체객체의 생성에 관련된 패턴으로서 특정 클래스의 인스턴스가 오직 하나임을 보장하고 이 인스턴스에 접근할 방법을 제공합니다.
- 퍼사드 패턴 (Facade Pattern)목적 : 구조범위 : 객체건물의 정문에 있는 안내소처럼 개발자가 사용해야 하는 서브 시스템의 가장 앞쪽에 위치하면서 하위 시스템에 있는 객체들을 사용할 수 있도록 하는 역할을 합니다. 시스템의 복잡성을 줄이기 위해 서브 시스템을 구조화하고 서브 시스템으로의 접근을 하나의 퍼사드 객체로 제공하는 패턴입니다.
- 옵저버 패턴 (Observer Pattern)목적 : 행위범위 : 객체객체의 상태변화를 관찰하는 관찰자들, 즉 옵저버들의 목록을 객체에 등록하여 상태 변화가 있을 때마다 메서드 등을 통해 객체가 직접 목록의 각 옵저버에게 통지하도록 하는 패턴입니다.
- 스트래티지 패턴 (Strategy Pattern)목적 : 행위범위 : 객체알고리즘을 담당하는 각각의 클래스를 만들어 책임을 분산하기 위한 목적으로 만든 행위 패턴입니다.
- 팩토리 패턴 (Factory Pattern)목적 : 생성범위 : 클래스객체를 생성하기 위한 인터페이스를 정의하지만 어떤 클래스의 인스턴스를 생성할지에 대한 결정은 하위 클래스에서 이루어지도록 인스턴스 생성의 책임을 떠넘기는 패턴입니다.
- 어댑터 패턴 (Adapter Pattern)목적 : 구조범위 : 클래스, 객체클래스의 인터페이스를 사용자가 기대하는 다른 인터페이스로 변환하는 패턴으로, 호환성이 없는 인터페이스 때문에 함께 동작할 수 없는 클래스들이 함께 동작하도록 해줍니다.
-싱글턴 패턴 → iOS 애플리케이션의 다양한 곳에 사용되고 있다.
- 앱 전체에 하나 존재하는 UIApplication 객체
- 파일 접근을 돕는 FileManager
- 알림 센터 NotificationCenter 객체
- 데이터 지속성이 필요한 정보(앱 내 설정) UserDefaults 객체
- 네트워크 통신을 위한 URLSession 객체
MVC패턴
Model / View / Controller로 나누는 패턴.
iOS 에서는 ViewController가 있는데, 규모가 큰 프로젝트에서는 이 VC가 점점 커지고 무거워지면서
Massive ViewController라는 별명을 가지고 있기도한 패턴이다.
Model에서는 애플리케이션에서 사용할 데이터들을 관리,
View는 유저 인터페이스를 표현 및 관리. → 사용자에게 보여주고 , 사용자가 조작할 수 있게 함.
Controller는 View와 Model의 다리 역할을 해 View의 입력을 Model이 반영하고, Model의 변화를 View에 갱신하는 역할을 한다.
하지만, 애플의 MVC 패턴은 기존 MVC 패턴과 다르다. View와 Controller가 강하게 연결되어 있어 View Controller가 거의 모든 일을 한다.
MVVM 패턴
MVVM 패턴은 Model / View / ViewModel로 이루어져있는 패턴이다.
기능
- Model은 데이터 구조체가 들어간다.
- → 데이터의 형상 그자체
- View는 MVC패턴에서 ViewController의 View에 해당하는 부분
- → 보여주는 것을 담당
- ViewModel은 MVC패턴에서 ViewController의 로직에 해당하는 부분이 들어간다.
- → 보여주기위한 데이터를 관리
MVC에서 Controller를 빼고 ViewModel을 추가한 패턴. 여기서 View Controller가 View가 되고, ViewModel이 중간 역할을 한다.
View와 ViewModel 사이에 Binding(바인딩-연결고리)가 있다. ViewModel은 Model에 변화를 주고,
ViewModel을 업데이트하는데 이 바인딩으로 인해 View도 업데이트를 한다.
ViewModel은 View에 대해 아무것도 모르기 때문에 테스트가 쉽고 바인딩으로 인해 코드 양을 줄일 수 있다.
과정
- 사용자가 화면에서 Action을 취하면 Command Pattern으로 View → ViewModel로 전달됩니다.
- ViewModel 이 Model에게 data를 요청합니다.
- Model은 요청받은 data를 통해 update된 data를 ViewModel로 전달합니다.
- ViewModel은 응답받은 데이터를 가공해서 저장합니다.
- View는 ViewModel과의 Data Binding을 통해서 자동으로 갱신됩니다.
여기서 Command Pattern 이란 ?
"Command = 명령어"실행될 기능을 추상화, 캡슐화하여 한 클래스에서 여러 기능을 실행할 수 있도록 하는 패턴입니다.
여기서 Data Binding 이란 ?
view와 로직이 분리되어 있어도 한 쪽이 바뀌면 다른 쪽도 업데이트가 이루어 지는 것입니다.
iOS 에서 Data Binding을 하는 방법에는 이런 것들이 있습니다.
- KVO
- Delegation
- Functional Reactive Programming
- Property Observer
-MVVM의 장점
- 유지보수에 좋다.
- 자동화된 테스팅에 적합한 모델이다 ( View Model과 View 간의 의존성이 없기 때문에 )
- 새로운 개발자라도 빠르게 적응이 가능하고 개발이 가능한 수준의 난이도와 복잡성
단점 → 단순한 프로젝트를 개발하기에는 MVC에 비해서는 긴코드를 작성해야한다.
실무에서는!!
회사에서 사용하는 모든 코드들은 이후에 새로운 기능이 추가될 확률이 굉장히 높고, 유지보수 및 테스트가 용이해야하기 때문에 많은 회사들이 MVVM 패턴을 채택하는 경향이 있다.
그렇기 때문에 MVC가 어느정도 익숙해졌고, 새로운 패턴을 적용을 하기위해서는 MVVM은 필수로 익혀야할 것
'모바일앱 > iOS' 카테고리의 다른 글
비즈니스 로직 (0) | 2022.03.21 |
---|---|
TIL 로컬라이징, 써드파티 (0) | 2022.03.19 |
로그를 출력할 때 사용하는 함수들 (0) | 2022.03.18 |
error - Command CompileSwiftSources failed with a nonzero exit code (0) | 2022.03.18 |
View의 계층구조 (0) | 2022.03.14 |
error - Extensions must not contain stored properties (0) | 2022.03.13 |
코코아팟 Hero 라이브러리 (0) | 2022.03.11 |
앱의 다크모드를 바꾸는 여러가지 방법 (0) | 2022.03.09 |