1. Design Pattern 이란?
- Erich Gamma, Richard Helm, Ralph Johnson, John Vlissides
- 위 4명은 the Gang of Four 또는 GoF라 불림.
- 자주 사용되는 23개의 디자인 패턴에 ‘이름’을 붙이고 정리하여
Elements of Reusable Object-Oriented Software를 발간.
2. Design Patten이 중요한 이유
재사용성,확장을 위해 많은 사람들이 노력한 정리된 결과물- 개발자 간의 프로그램 구조에 대한
용어의통일
3. Introduction
- “Program to an ‘interface’, not an ‘implementation’.”
- clients remain unaware of the specific types of objects they use, as long as the object adheres to the interface
- clients remain unaware of the classes that implement these objects; clients only know about the abstract class(es) defining the interface
- leads to dynamic binding and polymorphism, which are central features of object-oriented programming
- Composition over inheritance: “Favor ‘object composition’ over ‘class inheritance’.”
4. GoF에서 다루는 Design Pattern 목록
1. Creation
Creational patterns are ones that create objects for you, rather than having you instantiate objects directly. This gives your program more flexibility in deciding which objects need to be created for a given case.
Abstract factory patterngroups object factories that have a common theme.Builder patternconstructs complex objects by separating construction and representation.Factory method patterncreates objects without specifying the exact class to create.Prototype patterncreates objects by cloning an existing object.Singleton patternrestricts object creation for a class to only one instance.
2. Structural
These concern class and object composition. They use inheritance to compose interfaces and define ways to compose objects to obtain new functionality.
Adapterallows classes with incompatible interfaces to work together by wrapping its own interface around that of an already existing class.Bridgedecouples an abstraction from its implementation so that the two can vary independently.Compositecomposes zero-or-more similar objects so that they can be manipulated as one object.Decoratordynamically adds/overrides behaviour in an existing method of an object.Facadeprovides a simplified interface to a large body of code.Flyweightreduces the cost of creating and manipulating a large number of similar objects.Proxyprovides a placeholder for another object to control access, reduce cost, and reduce complexity.
3. Behavioral
Most of these design patterns are specifically concerned with communication between objects.
Chain of responsibilitydelegates commands to a chain of processing objects.Commandcreates objects which encapsulate actions and parameters.Interpreterimplements a specialized language.Iteratoraccesses the elements of an object sequentially without exposing its underlying representation.Mediatorallows loose coupling between classes by being the only class that has detailed knowledge of their methods.Mementoprovides the ability to restore an object to its previous state (undo).Observeris a publish/subscribe pattern which allows a number of observer objects to see an event.Stateallows an object to alter its behavior when its internal state changes.Strategyallows one of a family of algorithms to be selected on-the-fly at runtime.Template methoddefines the skeleton of an algorithm as an abstract class, allowing its subclasses to provide concrete behavior.Visitorseparates an algorithm from an object structure by moving the hierarchy of methods into one object.