informatique:design_pattern
Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente | ||
informatique:design_pattern [19/01/2015 18:59] – [best-practice-software-engineering's Patterns map] cyrille | informatique:design_pattern [03/03/2023 14:56] (Version actuelle) – [Documentation] SOLID principles - Increased maintainability, Increased testability, Increased flexibility, Better code organization cyrille | ||
---|---|---|---|
Ligne 6: | Ligne 6: | ||
Commencer par lire: | Commencer par lire: | ||
- | * [[http:// | + | * <del>[[http:// |
* [[http:// | * [[http:// | ||
* | * | ||
Ligne 17: | Ligne 17: | ||
* [[http:// | * [[http:// | ||
* [[http:// | * [[http:// | ||
- | | + | |
+ | |||
+ | [[https:// | ||
+ | | ||
+ | * Single Responsibility Principle (SRP) | ||
+ | * The SRP states that a class should have only one reason to change. In other words, a class should only have one responsibility and be focused on doing one thing well. | ||
+ | * Open/Closed Principle (OCP) | ||
+ | * The OCP states that a class should be open for extension, but closed for modification. | ||
+ | * Liskov Substitution Principle (LSP) | ||
+ | * The LSP states that objects of a superclass should be able to be replaced with objects of a subclass without affecting the correctness of the program. In other words, a subclass should be a substitute for its superclass. | ||
+ | * Interface Segregation Principle (ISP) | ||
+ | * The ISP states that classes should not be forced to implement interfaces they do not use. This principle can be applied by creating smaller, more focused interfaces that define specific tasks | ||
+ | * Dependency Inversion Principle (DIP) | ||
+ | * The DIP states that high-level modules should not depend on low-level modules, but both should depend on abstractions. This principle helps to reduce the coupling between modules | ||
==== best-practice-software-engineering' | ==== best-practice-software-engineering' | ||
Ligne 29: | Ligne 43: | ||
* Architectural Patterns express a fundamental structural organization or schema for software systems. They provide a set of predefined subsystems, specify their responsibilities, | * Architectural Patterns express a fundamental structural organization or schema for software systems. They provide a set of predefined subsystems, specify their responsibilities, | ||
* [[# | * [[# | ||
- | * Dependency Injection | + | * [[# |
* Structural Design Patterns are concerned with how classes and objects are composed together to form larger structures. [GoF, " | * Structural Design Patterns are concerned with how classes and objects are composed together to form larger structures. [GoF, " | ||
- | * Facade | + | * [[#facade|Facade]] |
* Decorator | * Decorator | ||
* Proxy | * Proxy | ||
- | * Data Access Object | + | * Data Access Object |
- | * Transfer Object | + | * [[# |
* Creational Design Patterns abstract the instantiation process. They help make a system independent of how its objects are created, composed, and represented. [GoF, " | * Creational Design Patterns abstract the instantiation process. They help make a system independent of how its objects are created, composed, and represented. [GoF, " | ||
- | * Factory Method | + | * [[# |
- | * Abstract Factory | + | * [[# |
* Objectpool | * Objectpool | ||
- | * Singleton | + | * [[# |
* Behavioral Design Patterns are concerned with algorithms and the assignment of responsibilities between objects. [GoF, " | * Behavioral Design Patterns are concerned with algorithms and the assignment of responsibilities between objects. [GoF, " | ||
* Iterator | * Iterator | ||
- | * Observer | + | * [[# |
* Event Listener | * Event Listener | ||
- | * Strategy | + | * [[# |
The diagram below shows the relationships between the patterns described in [[http:// | The diagram below shows the relationships between the patterns described in [[http:// |
informatique/design_pattern.txt · Dernière modification : 03/03/2023 14:56 de cyrille