Compound Pattern 이란?
일련의 패턴을 함께 사용하여 다양한 디자인 문제를 해결하는 것을 컴파운드 패턴 이라고 부릅니다.
다만 패턴 몇개를 결합해서 쓴다고 무조건 컴파운드 패턴이 되는 것은 아닙니다.
컴파운드 패턴이라면 여러가지 문제를 해결하기 위한 용도로 쓰일수 있는 일반적인 해결책이여야 합니다.
패턴 소개
Compound Pattern의 대표적인 예인 MVC 패턴에 대하여 글을 작성하였습니다. 함께 보실까요?
iTunes같은 MP3 플레이어를 사용한다고 해봅시다.
소프트웨어 에서 제공해주는 인터페이스를 사용하여 새로운 노래를 추가하거나 재생목록을 관리하거나 트랙 이름을 바꿀 수 있습니다. 다양한 데이터가 들어있는 DB는 그 소프트웨어에서 알아서 관리해 줍니다.
곡을 재생하고, 재생중인 곡의 정보등 다양한 정보를 사용자 인터페이스에 보여주는 일도 소프트웨어에서 처리하게되죠!
그런일을 해주는 게 바로 MVC(Model-View-Controller) 입니다.
◆ 뷰
모델을 표현하는 방법을 제공합니다. 일반적으로 화면에 표시하기 위해 필요한 상태 및 데이터는 모델에서 직접 가져옵니다.
◆ 컨트롤러
사용자로부터 입력을 받아 그것이 모델에게 어떠한 의미가 있는지 파악합니다.
◆ 모델
모델에는 데이터, 상태, 비지니스 로직 이 들어있습니다. 뷰와 컨트롤러 에서 모델의 상태를 조작하거나 가져오기위한 인터페이스를 제공하고, 모델에서 자신의 상태 변화에 대해서 옵저버들한태 연락을 해주긴 하지만, 기본적으로 모델은 뷰나 컨트롤러에게는 관심이 없습니다.
다음 그림을 함께 보시죠!
1) 사용자는 뷰하고만 접속할 수 있습니다.
뷰는 모델을 시각화 하는 부분입니다. 뷰에 대해서 사용자가 뭔가를 하면 뷰에서 컨트롤러한테 사용자가 어떤일을 했는지 알려줍니다. 그러면 컨트롤러가 상황에 맞게 처리합니다.
2) 컨트롤러가 모델에게 상태를 변경하라고 요청합니다.
컨트롤러는 사용자의 요청을 해석하고, 해석된 결과에 따라 모델을 어떤식으로 조작해야 하는지 결정합니다.
3) 컨트롤러에서 뷰를 변경해달라고 요청할 수 있습니다.
뷰로부터 어떤 요청을 컨트롤러가 받았을때, 그 요청의 결과로 뷰를 바꿀 수 있습니다. 예를 들어 어떤 버튼의 활성 과 비활성 같은것이 있을것 입니다.
4) 상태가 변경됬다면 모델에서 뷰한태 그 사실을 알립니다.
사용자의 행동때문이든, 다른 내부적인 변화 때문이든, 모델에서 뭔가 바뀌면 모델에서 뷰한테 상태가 변결되었음을 알립니다
5) 뷰에서 모델한테 상태를 요청합니다.
뷰에서 화면에 표시할 상태는 모델로부터 직접 가져옵니다. 예를들어 모델에서 뷰한테 새로운 곡이 재생되기 시작했다고 알려주면 뷰에서 모델한태 곡 제목을 요청하고, 이를 받아 화면에 출력합니다.
컨트롤러에서 뷰를 바꾸라는 요청이 있을때도 뷰에서 모델한태 상태를 알려달라 요청할 수 있습니다.
이제 MVC를 여러 패턴들의 집합으로서 살펴봐야겠죠? 간단한 그림부터 봅시다.
모델에서는 옵저버 패턴을 사용하여 상태가 바뀔때마다 뷰와 컨트롤러에게 연락을 취합니다.
뷰와 컨트롤러에서는 스트레티지 패턴을 사용하죠. 컨트롤러는 뷰의 행동에 해당하며, 다른 행동을 하고싶다면 간단하게 다른 컨트롤러로 교환하기만 하면 됩니다.
뷰 안에서는 내부적으로 컴포지트 패턴을 사용하여 윈도우, 버튼 등 다양한 구성요소를 관리합니다.
좀더 상세하게 살펴보러 가시죠!
1) 옵저버 패턴
모델(옵저버블)에서는 옵저버 패턴을 써서 상태가 변경되었을 때 그 모델하고 연관된 객체들(옵저버)에게 연락을 합니다.
옵저버 패턴을 이용해서 뷰 및 컨트롤러로부터 완전히 독립시킬 수 있다.
한 모델에서 서로 다른 뷰를 사용할 수도 있고, 여러 개의 뷰를 동시에 사용하는 것도 가능하답니다!
2) 스트래티지 패턴
뷰와 컨트롤러는 고전적인 스트래티지 패턴으로 구현되어 있습니다. 따라서 뷰 객체를 여러 전략을 써서 설정할 수 있으며 컨트롤러가 그 전략을 제공한답니다!
뷰에서는 애플리케이션의 겉모습에만 신경쓰고, 사용자의 행동에 대한 처리는 모두 컨트롤러에게 맡깁니다.
스트래티지 패턴을 이용하므로 뷰를 모델로부터 분리시키는 데에도 도움이 됩니다.
사용자가 요청한 내역을 처리하기 위해서 모델하고 얘기를 해야 하는 부분이 컨트롤러기 때문에 뷰는 그 방법을 전혀 알지 못합니다.
3) 컴포지트 패턴
디스플레이는 여러 단계로 겹쳐져 있는 일련의 윈도우, 패널, 버튼, 텍스트 레이블 등으로 구성됩니다.
각 디스플레이 항목은 복합 객체(윈도우 등) 또는 잎(버튼 등)이 될 수 있습니다.
컨트롤러에서 뷰한테 화면을 갱신해 달라고 요청하면 최상위 뷰 구성요소한테만 갱신하라고 얘기하면 됩니다.
나머지는 컴포지트 패턴에 의해 자동으로 처리됩니다.
'BackEnd > Design Patterens' 카테고리의 다른 글
[Design Patterns] Proxy Pattern : 프록시 패턴 (0) | 2022.01.13 |
---|---|
[Design Patterns] State Pattern : 스테이트 패턴 (0) | 2022.01.13 |
[Design Patterns] Composite Pattern : 컴포지트 패턴 (0) | 2022.01.13 |
[Design Patterns] Iterator Pattern : 이터레이터 패턴 (0) | 2022.01.13 |
[Design Patterns] Template Method Pattern : 템플릿 메소드 패턴 (0) | 2022.01.13 |
댓글