If your classes are globals, use fully qualified names
TL;DR: Don't use abbreviations in subclasses
Problems
Readability
Mistakes
Solutions
Rename your classes to provide context
Use modules, namespaces or fully qualified names
Sample Code
Wrong
abstract class PerserveranceDirection {
}
class North extends PerserveranceDirection {}
class East extends PerserveranceDirection {}
class West extends PerserveranceDirection {}
class South extends PerserveranceDirection {}
//Subclasses have short names and meaningless outside the hierarchy
//If we reference East we might mistake it for the Cardinal Point
Right
abstract class PerserveranceDirection {
}
class PerserveranceDirectionNorth extends PerserveranceDirection {}
class PerserveranceDirectionEast extends PerserveranceDirection {}
class PerserveranceDirectionWest extends PerserveranceDirection {}
class PerserveranceDirectionSouth extends PerserveranceDirection {}
//Subclasses have fully quallified names
Detection
Automatic detection is not an easy task. We could enforce local naming policies for subclasses.
Tags
- Naming
Conclusion
Choose your names wisely.
If your language supports it, use modules, namespaces and local scopes.
Relations
data:image/s3,"s3://crabby-images/3d1fe/3d1fea54a11636b2b932df99681c97a18d7eb57f" alt="mcsee"
Code Smell 11 - Subclassification for Code Reuse
Maxi Contieri ・ Oct 30 '20
More Info
Credits
Photo by Edvard Alexander Rølvaag on Unsplash
The programmer's primary weapon in the never-ending battle against slow system is to change the intramodular structure. Our first response should be to reorganize the modules' data structures.
Frederick P. Brooks
data:image/s3,"s3://crabby-images/3d1fe/3d1fea54a11636b2b932df99681c97a18d7eb57f" alt="mcsee"
Software Engineering Great Quotes
Maxi Contieri ・ Dec 28 '20
This article is part of the CodeSmell Series.
Top comments (0)