A collection of essential design patterns for software development using practical examples, such Singleton, Factory Method, Observer, and more, to help developers write more efficient and maintainable code.
- Abstract Factory - Provides an interface for creating families of related or dependent objects without specifying their concrete classes.
- Builder - Separates the construction of a complex object from its representation, allowing the same construction process to create different representations.
- Factory Method - Creates objects without specifying the exact class of object that will be created.
- Protoype - Creates new objects by copying an existing object, known as the prototype.
- Singleton - Ensures a class has only one instance and provides a global point of access to it.
- Adapter - Allows incompatible interfaces to work together by converting one interface into another.
- Bridge - Decouples an abstraction from its implementation so that the two can vary independently.
- Composite - Composes objects into tree structures to represent part-whole hierarchies, allowing clients to treat individual objects and compositions uniformly.
- Decorator - Adds behavior or responsibilities to an object dynamically without altering its structure.
- Facade - Provides a simplified interface to a larger body of code, making it easier to use.
- Flyweight - Reduces memory usage by sharing common parts of the state between multiple objects.
- Proxy - Provides a surrogate or placeholder for another object to control access to it.
- Chain of Responsibility - Passes a request along a chain of handlers until it is handled or reaches the end of the chain.
- Command - Encapsulates a request as an object, thereby allowing for parameterization and queuing of requests.
- Interpreter - Defines a representation for a language's grammar and provides an interpreter to process sentences in that language.
- Iterator - Provides a way to access elements of a collection sequentially without exposing its underlying representation.
- Mediator - Defines an object that encapsulates how a set of objects interact, promoting loose coupling.
- Memento - Captures and restores an object's internal state without violating encapsulation.
- Observer - Defines a one-to-many dependency between objects so that when one object changes state, all its dependents are notified.
- State - Allows an object to alter its behavior when its internal state changes.
- Strategy - Defines a family of algorithms, encapsulates each one, and makes them interchangeable.
- Template Method - Defines the skeleton of an algorithm in a method, deferring some steps to subclasses.
- Visitor - Separates an algorithm from the objects it operates on by allowing new operations to be added without modifying the objects.