principles:rule_of_explicitness
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
principles:rule_of_explicitness [2021-05-19 11:24] – old revision restored (2021-05-11 22:21) 2a04:ac00:4:d29:5054:ff:fe00:d387 | principles:rule_of_explicitness [2021-10-18 22:06] (current) – +++ restored +++ christian | ||
---|---|---|---|
Line 9: | Line 9: | ||
* [[contexts: | * [[contexts: | ||
* [[contexts: | * [[contexts: | ||
+ | * [[contexts: | ||
===== Principle Statement ===== | ===== Principle Statement ===== | ||
Line 34: | Line 34: | ||
* Avoid highly configurable modules. Instead implement varying behavior explicitly. | * Avoid highly configurable modules. Instead implement varying behavior explicitly. | ||
* Explicitly state which module to use | * Explicitly state which module to use | ||
- | * Avoid importing all classes of a given package/ | + | * Avoid importing all classes of a given package/ |
* Avoid '' | * Avoid '' | ||
* Explicitly name parameters | * Explicitly name parameters | ||
Line 84: | Line 84: | ||
* [[Generalization Principle]] (GP): RoE often results in specific solutions. Generality often requires stating something implicitly. | * [[Generalization Principle]] (GP): RoE often results in specific solutions. Generality often requires stating something implicitly. | ||
* [[Low Coupling]] (LC): Direct communication typically has the disadvantage of a higher coupling. Indirection reduces coupling but creates implicit/ | * [[Low Coupling]] (LC): Direct communication typically has the disadvantage of a higher coupling. Indirection reduces coupling but creates implicit/ | ||
- | + | * [[Don' | |
==== Complementary Principles ==== | ==== Complementary Principles ==== | ||
* [[Keep It Simple Stupid]] (KISS): Explicit solutions are often also simpler. | * [[Keep It Simple Stupid]] (KISS): Explicit solutions are often also simpler. | ||
- | * [[Murphy' | + | * [[Murphy' |
* [[Model Principle]] (MP): RoE states that [[anti-patterns: | * [[Model Principle]] (MP): RoE states that [[anti-patterns: | ||
+ | * [[Law of Leaky Abstractions]] (LLA): Often abstractions create a level of implicitness. Abstraction leaks are one reason why explicit solutions can be considered preferable. | ||
==== Principle Collections ==== | ==== Principle Collections ==== | ||
Line 103: | Line 102: | ||
===== Description Status ===== | ===== Description Status ===== | ||
/* Choose one of the following and comment out the rest: */ | /* Choose one of the following and comment out the rest: */ | ||
- | [[wiki: | + | /*[[wiki: |
- | /*[[wiki: | + | [[wiki: |
/ | / | ||
Line 112: | Line 111: | ||
* Martin Fowler: // | * Martin Fowler: // | ||
* Tim Peters: // | * Tim Peters: // | ||
+ | |||
+ | ===== Discussion ===== | ||
+ | |||
+ | Discuss this wiki article and the principle on the corresponding [[talk: | ||
principles/rule_of_explicitness.txt · Last modified: 2021-10-18 22:06 by christian