First programming lesson: Control structures. Senior developer lesson: avoid them.
Problems:
Too many decisions together
Coupling
Duplicated code
Violation of Open/Closed Principle.
A new condition should not change the main algorithm.
Nulls
Solutions
Polymorphism
Create hierarchies/compose objects following Open closed principle.
Use State pattern to model transitions.
Use Strategy Pattern/Method Object to choose for branches.
Examples
Discrete Values
State transition
Algorithm choice.
Sample Code
Wrong
class Mp3Converter { | |
convertToMp3(source, mimeType) { | |
if(mimeType.equals("audio/mpeg")) { | |
this.convertMpegToMp3(source) | |
} else if(mimeType.equals("audio/wav")) { | |
this.convertWavToMp3(source) | |
} else if(mimeType.equals("audio/ogg")) { | |
this.convertOggToMp3(source) | |
} else if(...) { | |
// Lots of new clauses | |
} |
Right
class Mp3Converter { | |
convertToMp3(source, mimeType) { | |
const foundConverter = this.registeredConverters. | |
find(converter => converter.handles(mimeType)); | |
// Do not use metaprogramming to find and iterate converters | |
// since this is another problem. | |
if (!foundConverter) { | |
throw new Error('No converter found for ' + mimeType); | |
} | |
foundConverter.convertToMp3(source); | |
} | |
} |
Detection
Since there are valid cases for If/else usages, we should not pull the plug and forbid these instructions. We can put a ratio of if statements/other statements as a warning instead.
Relations
More info
data:image/s3,"s3://crabby-images/3d1fe/3d1fea54a11636b2b932df99681c97a18d7eb57f" alt="mcsee"
How to Get Rid of Annoying IFs Forever
Maxi Contieri ・ Nov 9 '20
Credits
Photo by Adarsh Kummur on Unsplash
If debugging is the process of removing software bugs, then programming must be the process of putting them in.
Edsger Dijkstra
Top comments (3)
The code isn't at all different, not sure of the intent here?
If you see the code exactly the same is due to a bug in dev.to cache. Try refreshing the cache
It's been a couple of years and it's definitely the same for me :)