프로그래밍 기술/Escort GoF의 디자인 패턴 C#

[소프트웨어 패턴 C#] 25. 방문자 패턴(Visitor Pattern)

언제나휴일 2016. 4. 17. 13:36
반응형

25. 방문자 패턴(Visitor Pattern)

 

 

 프로그래밍을 하다 보면 여러 구성 요소들로 구성된 개체를 정의해야 하는 경우는 매우 흔한 일입니다. 그리고, 특정 명령을 수행함에 있어 내부 구성 요소 개체들의 형식에 따라 적용해야 할 구체적 행위가 다른 경우가 있을 것입니다. 이와 같은 경우에 방문자 패턴을 사용하면 개체들의 형식에 따라 적용해야 할 구체적 행위를 분리하여 정의할 수 있습니다. 이는 새로운 행위를 정의할 필요가 생길 경우에도 구성 요소 형식을 변경하지 않으면서 추가할 수 있게 됩니다.

 

 방문자 패턴에서는 개체를 구성하는 여러 요소 개체들에게 요소의 형식에 따라 수행할 구체적 작업을 방문자에 정의하게 됩니다. 대신 요소의 형식에서는 방문자를 수용하는 메서드를 제공을 하고 방문자를 통해 자신을 제어하기 위한 약속된 메서드를 사용을 하면 방문자가 구체적인 작업을 대행하게 됩니다. 이와 같이 방문자 패턴을 사용하면 요소 형식에 따라 수행할 구체적 작업을 분리하여 구현할 수 있다는 장점과 새로운 연산을 요소 형식 변경 없이 가능하다는 장점이 있습니다. 하지만, 정보 은닉이 필요한 부분까지  방문자에게 노출을 해야 하기 때문에 신뢰성을 떨어지는 원인이 되기도 합니다.  또한, 요소의 형식이 추가가 되면 방문자 형식에 추가된 요소 형식의 개체에 대한 연산을 추가해야 하는 숨어있는 비용이 발생합니다. 만약, 요소 형식이 추가할 확률이 높다면 방문자 패턴은 예상치 못했던 비용이 발생할 수 있습니다.

 

 참고 사항으로 방문자를 수용하는 메소드에서는 방문자의 형식과 요소의 형식에 따라 수행되는 연산이 달라지게 되기 때문에 이중 디스패치 기법을 표현해야 하는데 언어에서 제공된다면 굳이 방문자 패턴을 사용할 필요가 없습니다.

 


방문자 패턴(Visitor Pattern)


 

Visitor.zip



2016/04/29 - [프로그래밍 기술/Escort GoF의 디자인 패턴 C#] - [C#] 방문자 패턴(Visitor Pattern) - 개요, 시나리오


2016/04/29 - [프로그래밍 기술/Escort GoF의 디자인 패턴 C#] - [C#] 방문자 패턴(Visitor Pattern) - 설계(Design)


2016/04/29 - [프로그래밍 기술/Escort GoF의 디자인 패턴 C#] - [C#] 방문자 패턴(Visitor Pattern) - 구현


반응형