Python 디자인 패턴
개요
최신 소프트웨어 개발은 복잡한 비즈니스 요구 사항을 해결해야합니다. 또한 향후 확장 성 및 유지 관리 가능성과 같은 요소도 고려해야합니다. 이러한 목표를 달성하려면 소프트웨어 시스템을 잘 설계해야합니다. 디자인 패턴은 이러한 시스템에서 중요한 역할을합니다.
디자인 패턴을 이해하기 위해 아래 예를 살펴 보겠습니다.
모든 자동차의 디자인은 기본 디자인 패턴, 네 바퀴, 스티어링 휠, 가속 브레이크 클러치 등의 핵심 드라이브 시스템을 따릅니다.
따라서 반복적으로 제작 / 생산되는 모든 것들은 필연적으로 디자인 패턴을 따라야합니다. 자동차, 자전거, 피자, ATM 기계, 무엇이든… 심지어 소파 베드까지.
소프트웨어에서 일부 논리 / 메커니즘 / 기술을 코딩하는 표준 방식이 된 디자인은 소프트웨어 디자인 패턴으로 알려 지거나 연구됩니다.
디자인 패턴이 중요한 이유는 무엇입니까?
디자인 패턴 사용의 이점은 다음과 같습니다.
입증 된 접근 방식을 통해 일반적인 설계 문제를 해결하는 데 도움이됩니다.
잘 문서화되어 있기 때문에 이해가 모호하지 않습니다.
전체 개발 시간을 단축합니다.
향후 확장 및 수정을 다른 것보다 더 쉽게 처리 할 수 있습니다.
일반적인 문제에 대한 검증 된 솔루션이므로 시스템 오류를 줄일 수 있습니다.
디자인 패턴의 분류
GoF (Gang of Four) 디자인 패턴은 생성, 구조 및 행동의 세 가지 범주로 분류됩니다.
창조 패턴
생성 디자인 패턴은 시스템의 나머지 부분에서 객체 생성 로직을 분리합니다. 당신이 물건을 만드는 대신 창조 패턴이 당신을 위해 만들어줍니다. 생성 패턴에는 Abstract Factory, Builder, Factory Method, Prototype 및 Singleton이 포함됩니다.
창조 패턴은 언어의 동적 특성 때문에 파이썬에서 일반적으로 사용되지 않습니다. 또한 언어 자체는 우리가 충분히 우아한 방식으로 만드는 데 필요한 모든 유연성을 제공하며, 싱글 톤이나 팩토리와 같은 어떤 것도 맨 위에 구현할 필요가 거의 없습니다.
또한 이러한 패턴은 new 연산자를 사용하여 직접 개체를 인스턴스화하는 대신 생성 논리를 숨기면서 개체를 만드는 방법을 제공합니다.
구조 패턴
때로는 처음부터 시작하는 대신 기존 클래스 집합을 사용하여 더 큰 구조를 구축해야합니다. 구조적 클래스 패턴이 상속을 사용하여 새로운 구조를 만드는 곳입니다. 구조적 객체 패턴은 합성 / 집계를 사용하여 새로운 기능을 얻습니다. Adapter, Bridge, Composite, Decorator, Façade, Flyweight 및 Proxy는 구조 패턴입니다. 클래스 계층 구조를 구성하는 가장 좋은 방법을 제공합니다.
행동 패턴
행동 패턴은 객체 간의 통신을 처리하는 가장 좋은 방법을 제공합니다. 패턴은 다음과 같은 범주에 속합니다. 방문자, 책임 체인, 명령, 통역사, 반복자, 중재자, Memento, 관찰자, 상태, 전략 및 템플릿 방법은 행동 패턴입니다.
시스템의 동작을 나타 내기 때문에 일반적으로 소프트웨어 시스템의 기능을 설명하는 데 사용됩니다.
일반적으로 사용되는 디자인 패턴
하나씩 일어나는 것
모든 디자인 패턴 중에서 가장 논란이 많고 유명한 패턴 중 하나입니다. 지나치게 객체 지향 언어에서 사용되며 전통적인 객체 지향 프로그래밍의 중요한 부분입니다.
Singleton 패턴은 다음에 사용됩니다.
로깅을 구현해야 할 때. 로거 인스턴스는 시스템의 모든 구성 요소에서 공유됩니다.
구성 파일은 정보 캐시를 유지 관리하고 시스템의 모든 다양한 구성 요소에서 공유해야하기 때문에이를 사용합니다.
데이터베이스에 대한 연결 관리.
다음은 UML 다이어그램입니다.
class Logger(object):
def __new__(cls, *args, **kwargs):
if not hasattr(cls, '_logger'):
cls._logger = super(Logger, cls).__new__(cls, *args, **kwargs)
return cls._logger
이 예에서 Logger는 Singleton입니다.
__new__가 호출되면 일반적으로 해당 클래스의 새 인스턴스를 생성합니다. 재정의 할 때 먼저 싱글 톤 인스턴스가 생성되었는지 여부를 확인합니다. 그렇지 않은 경우 슈퍼 호출을 사용하여 생성합니다. 따라서 Logger에서 생성자를 호출 할 때마다 항상 똑같은 인스턴스를 얻습니다.
>>>
>>> obj1 = Logger()
>>> obj2 = Logger()
>>> obj1 == obj2
True
>>>
>>> obj1
<__main__.Logger object at 0x03224090>
>>> obj2
<__main__.Logger object at 0x03224090>