반응형

소프트웨어 설계 73

[C#] 메멘토 패턴(Memento Pattern) - 개요, 시나리오

20. 메멘토 패턴(Memento Pattern) 20.1 개요 메멘토 패턴은 개체의 상태를 기록해 놓았다가 원래 상태로 복원을 할 필요가 있을 때 기록해 놓은 것을 사용하는 패턴입니다. 메멘토 패턴은 실행 취소 기능을 지원하고자 할 때 많이 사용됩니다. 간단한 예를 들어볼께요. 어떠한 응용에서 특정 기능을 수행할 것을 요청하기 전에 원본 개체에게 메멘토 개체를 요청합니다. 원본 개체는 자신의 상태 정보에 대한 스냅샷인 메멘토 개체를 생성하여 반환합니다. 그리고, 특정 기능을 수행하다가 수행 이전 상태로 복원이 필요하게 되면 반환 받았던 메멘토 개체를 원본 개체에게 전달하여 복원할 것을 요청합니다. 원본 개체는 전달받은 메멘토 개체에 보관해 두었던 이전 상태 값을 얻어와서 자신의 상태를 복원을 하는 것입..

[C#] 중재자 패턴(Mediator Pattern) - 구현

19. 중재자 패턴(Mediator Pattern) [그림] 중재자 패턴(Mediator Pattern) 클래스 다이어그램 19.4 구현 중재자 패턴에 대한 예제 프로그램을 구현하는 순서는 InnerModue 군, Mediator 군, Camera와 데모 코드순으로 하겠습니다. 19.4.1 InnerModule 군 InnerModule은 Shutter와 Iris의 기반 클래스입니다. 중재자 패턴에서 Shutter 개체와 Iris 개체는 서로에 대한 정보를 알 필요가 없게 하기 위해 중재자의 위치를 알아야 합니다. 그리고, 중재자 패턴에서는 Shutter 개체와 Iris 개체 사이에 주고 받아야 할 상호작용을 해야 하는 것을 중재자 개체에게 전달만 하면 되게 구현해야 합니다. 여기에서는 내부 모듈 개체 생..

[C#] 중재자 패턴(Mediator Pattern) - 설계(Design)

19. 중재자 패턴(Mediator Pattern) 19. 3 디자인 중재자 패턴에 대한 설명을 위한 예제는 카메라의 반 자동 모드에서 중재자를 통해 조리개 값의 변화와 셔터 스피드의 변화에 대한 상호작용을 하는 프로그램을 작성해 볼께요. 프로그램에는 사용자와 상호작용을 하는 Camera 개체가 있습니다. Camera 개체 내부에는 내부 중재자 개체인 InnerMode 형식의 개체가 있고 셔터 스피드를 관리하는 Shutter, 조리개를 관리하는 Iris라 정하였습니다. Camera 형식의 개체는 내부에 InnerMediator 개체와 Iris, Shutter 개체로 구성되어 있습니다. 사용자에 의해 촬영 모드가 변경 요청이 오면 이를 InnerMediator 개체에게 전달합니다. 그리고, 셔터 스피드 값..

[C#] 중재자 패턴(Mediator Pattern) - 개요, 시나리오

19. 중재자 패턴(Mediator Pattern) 19.1 개요 중재자 패턴은 프로그램의 상호작용을 해야 하는 개체들이 서로 복잡하게 관계를 맺고 있을 경우에 상호작용에 관련된 행동을 별도의 형식으로 정의하여 중재를 맡는 개체를 두게 하는 패턴입니다. 프로그램을 작성하다 보면 복잡한 상호작용을 해야 하는 경우 개체들 간의 결합도는 강하게 되고 유연성이 떨어져서 재 사용하기 힘든 경우가 발생합니다. 특히, 하나의 개체에서 다른 개체에게 일방적으로 명령을 하는 것이 아니라 명령을 받는 개체도 특정 조건에서 명령을 내린 개체에게 명령을 내릴 수 있는 경우에는 구조적으로 취약하게 됩니다. 이와 같은 경우에 중재자 패턴을 사용하면 전체적으로 강한 결합도를 부분적으로만 결합도가 강한 상태를 유지하고 많은 부분에서..

[C#] 반복자 패턴(Iterator Pattern) - 구현

18. 반복자 패턴(Iterator Pattern) [그림] 반복자 패턴 클래스 다이어그램 18.4 구현 반복자 패턴에 대한 예제 프로그램을 구현하는 순서는 Collection, Iterator, Arr과 ArrIterator, Tracer순으로 하겠습니다. 18.4.1 IContainer IContainer에서는 일반적으로 컬렉션에 필요한 메서드에 대한 구현 약속만 하면 되겠죠. 여기에서는 보관하는 메서드와 삭제, 전체 해제, 현재 보관된 수를 얻어오는 속성에 대한 약속을 하겠습니다. IIterator.cs using System; namespace Iterator { interface IIterator { void Begin(); bool MoveNext(); Object Current { get; ..

[C#] 반복자 패턴(Iterator Pattern) - 설계(Design)

18. 반복자 패턴(Iterator Pattern) 18. 3 디자인 C#에서는 IEnumerator, IEnumerable 인터페이스를 약속하고 ArrayList나 배열과 같은 컬렉션들이 이들 인터페이스를 구현 약속함으로써 사용자가 foreach 구문을 통해 컬렉션의 요소들을 반복적으로 접근할 수 있게 제공하고 있습니다. 여기에서는 이러한 부분이 C#에 제공하지 않는다는 관점에서 반복자 패턴을 표현해 보려고 합니다. 반복자 패턴에 대한 설명을 위한 예제 프로그램은 추상화 컬렉션을 파생받은 배열 형식에 대한 정의와 반복자를 파생받은 배열 반복자를 정의한 것이 맞게 작성된 것인지를 확인하는 예광탄으로 하겠습니다. 추상화 된 컬렉션에는 개체를 보관하거나 삭제할 수 있고 전체를 제거하거나 보관된 개체를 얻어올..

[C#] 반복자 패턴(Iterator Pattern) - 개요, 시나리오

18. 반복자 패턴(Iterator Pattern) 18.1 개요 프로그램을 하다 보면 개체들을 보관하는 컬렉션 개체를 사용하는 것은 매우 흔한 일입니다. 그리고, 컬렉션의 안전성을 유지하기 위해서는 개체를 보관하는 공간을 직접적으로 노출시키지 않게 됩니다. 하지만 사용자의 경우 컬렉션에 보관된 개체들의 정보를 검색할 수 있어야 하며 경우에 따라서는 보관된 개체들에 대해 반복된 작업을 수행하기를 원하는 경우가 있습니다. 반복자 패턴은 컬렉션 개체의 내부 저장 공간에 대해 직접적으로 노출하는 것을 막으면서 보관된 개체들에 대해 반복된 작업을 수행할 수 있는 방법을 제공하고자 할 때 사용하는 패턴입니다. 반복자 패턴에서는 컬렉션을 반복 순회하면서 작업을 수행할 필요가 있을 때 순회할 수 있는 도구 개체를 정..

[C#] 해석자 패턴(Interpreter Pattern) - 구현

17. 해석자 패턴(Interpreter Pattern) [그림] 해석자 패턴 클래스 다이어그램 17.4 구현 해석자 패턴에 대한 예제 프로그램을 구현하는 순서는 Picture, Expression 군, Macro와 데모 코드 순으로 하겠습니다. 17.4.1 Picture Picture에서는 단순히 사진의 이름과 색조, 명도, 채도의 값을 갖는 클래스로 구현을 하겠습니다. 시나리오를 위해 필요한 클래스이며 해석자 패턴과 관련되는 형식은 아닙니다. Expression.cs namespace Interpreter { abstract class Expression { public Expression Next{ get; set; } public Expression() { Next = null; } public ..

[C#] 해석자 패턴(Interpreter Pattern) - 개요, 시나리오

17. 해석자 패턴(Interpreter Pattern) 17.1 개요 해석자 패턴은 사용자가 표현하기 쉬운 표현을 사용하게 하고 이를 해석하는 개체를 통해 약속된 알고리즘을 수행할 수 있게 해 주는 패턴입니다. SQL 쿼리문이나 Command 창에서 프로그램 실행 시 필요한 인자를 전달할 때와 같은 경우 등에서 많이 사용될 수 있는 패턴입니다. 해석자 패턴에서는 사용자가 원하는 다양한 명령을 쉽게 표현할 수 있게 구문 약속을 해야 합니다. 그리고, 해석자에서는 이와 같이 약속된 구문을 입력 인자로 전달되었을 때 이를 해석을 할 수 있어야 합니다. 사용자로부터 전달된 입력 구문은 하나의 표현으로 종결되기도 하지만 여러 개의 표현으로 해석될 수도 있습니다.가령 "2 Add 3" 과 같은 표현은 피 연산자:..

[C#] 명령 패턴(Command Pattern) - 개요, 시나리오

16. 명령 패턴(Command Pattern) 16.1 개요 프로그래밍을 하다 보면 명령을 내리는 개체와 명령을 수행하는 개체를 나누는 작업은 매 번 있는 작업입니다. 그런데, 실제 요청한 작업을 수행하는 개체에서 수행에 필요한 알고리즘을 모두 포함시켰을 경우에 비슷한 형태의 여러 메서드를 구현하여야 하는 경우가 발생합니다. 경우에 따라서는 명령을 내리는 시점과 실제 명령을 수행하는 시점이 다르고 다양한 설정에 따라 구체적인 수행 알고리즘이 다른 경우도 발생합니다. 이와 같은 경우에 명령을 내리는 곳에서 일부 알고리즘을 정의하여 명령을 수행하는 개체의 메서드를 호출할 때 입력 인자로 전달하는 것이 더 효과적인 경우가 발생합니다. 이와 같은 경우에 명령 패턴은 효과적으로 사용할 수 있습니다. 명령 패턴은..

반응형