the 23 Gang of Four design patterns
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.
- groups object factories that have a common theme.
- constructs complex objects by separating construction and representation.
- creates objects without specifying the exact class to create.
- creates objects by cloning an existing object.
- restricts object creation for a class to only one instance.readme
These concern class and object composition. They use inheritance to compose interfaces and define ways to compose objects to obtain new functionality.
- allows classes with incompatible interfaces to work together by wrapping its own interface around that of an already existing class.
- decouples an abstraction from its implementation so that the two can vary independently.
- composes zero-or-more similar objects so that they can be manipulated as one object.
- dynamically adds/overrides behaviour in an existing method of an object.
- provides a simplified interface to a large body of code.
- reduces the cost of creating and manipulating a large number of similar objects.
- provides a placeholder for another object to control access, reduce cost, and reduce complexity.
Most of these design patterns are specifically concerned with communication between objects.
Chain of responsibility
- delegates commands to a chain of processing objects.
- creates objects which encapsulate actions and parameters.
- implements a specialized language.
- accesses the elements of an object sequentially without exposing its underlying representation.
- allows loose coupling between classes by being the only class that has detailed knowledge of their methods.
- provides the ability to restore an object to its previous state (undo).
- is a publish/subscribe pattern which allows a number of observer objects to see an event.
- allows an object to alter its behavior when its internal state changes.
- allows one of a family of algorithms to be selected on-the-fly at runtime.
- defines the skeleton of an algorithm as an abstract class, allowing its subclasses to provide concrete behavior.
- separates an algorithm from an object structure by moving the hierarchy of methods into one object.