Alan M. Davis: 201 Principles of Software Development
Table of Contents
Generalization Principle (GP)
Variants and Alternative Names
Context
Principle Statement
A generalized solution, that solves not only one but many problems, is better than a specific one.
Description
There are various ways to make a solution more generally applicable. In the simplest form this can be done by introducing a method with appropriate parameters. Other possibilities are classes, parametric types, callbacks, hook methods, etc.
A general solution abstracts from the specific tasks and solves a superset of them. Parameterization of some kind is used to specify what has to be done in a given situation.
A module can be more general than another one. But there are two aspects of this: First of all there is functionality. If module A
can do the same as module B
plus something more then A
is more general. The second aspect is the one of what has to be done in order to exploit the generality. An ideal case would be that nothing has to be done and the module just does more. Other possibilities are that a configuration file has to be changed, an attribute has to be set, an invocation parameter has to be adjusted, etc. The least general possibility would be a module which can be changed easily. This is still better than a rigid module but less general than modules which do not need such changes. This form of generality is often rather called “flexibility” 3).
Rationale
Specific solutions tend to be fragile. When requirements change, a specific solution might not fulfill them anymore. In contrast to that a more general solution is more stable so there will be less need to change it.
Moreover a generalized solution can be reused in a variety of other situations. A specific solution can only be reused when exactly the same requirements appear again. So a general solution is much more reusable.
Strategies
- Make modules configurable at runtime or deployment time by using configuration files.
- Use parameterizable modules(method parameters, object attributes, parametric types, etc.)
- Use constants
- Find suitable abstractions
Caveats
Making a module (typically a layer, a subsystem or an API) too general leads to the inner-platform effect. This means that the module is so general that it mirrors the functionality of the underlying platform without adding a benefit but only complexity.
Another problem is the turing tarpit. This means that the module is so general that arbitrarily complex tasks can be performed but those of interest, meaning the rather simple tasks that occur over and over again, are also difficult to do. This is a violation of the EUHM principle.
See also section contrary principles.
Origin
The term “generalization principle” is proposed here. Nevertheless the value of generalized solutions is well known at least since:
David L. Parnas: Designing Software for Ease of Extension and Contraction
Evidence
Relations to Other Principles
Generalizations
Specializations
Contrary Principles
- Keep It Simple Stupid (KISS): A generalized solution is typically not simple anymore. This is the typical conflict between generality and simplicity.
- Easy to Use and Hard to Misuse (EUHM): Too general solutions may lead to complicated usage of the module.
- Rule of Explicitness (RoE): RoE often results in specific solutions. Generality often requires stating something implicitly.
Complementary Principles
- Don't Repeat Yourself (DRY): A more general solution avoids duplication.
- Encapsulate the Concept that Varies (ECV): Encapsulating a varying concept typically results in a more generally applicable solution. This is especially true when an abstract concept is encapsulated by introducing an interface or an abstract class.
Principle Collections
Examples
Description Status
Further Reading
Discussion
Discuss this wiki article and the principle on the corresponding talk page.
Andrew Hunt and David Thomas: The Pragmatic Programmer: From Journeyman to Master
David L. Parnas: Designing Software for Ease of Extension and Contraction