2.0 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			2.0 KiB
		
	
	
	
	
	
	
	
title
| title | 
|---|
| Code Smells | 
Code Smells
A Code Smell in computer programming is a surface indication that there might be a problem regarding your system and the quality of your code. This problem might require refactoring or redesign to be corrected.
It is important to understand that smelly code may execute, but is not of good quality in one or more aspects.
Examples:
- Duplicated code - Blocks of code that have been replicated across the code base. This may indicate that you need to generalize the code into a function/module/component/service and call it in several places, or it may be that the way the code works in one place is completely unrelated to the way it works in another place, despite having been copied.
- Large classes - Classes having too many lines of code. This may indicate that the class is trying to do too many things, and needs to be broken up into smaller classes.
- Magic numbers - Variables (or ifstatements) scattered in the code that hold numeric values with no apparent meaning.
- Many-parameter methods - Methods that take more that 2 or 3 parameters usually indicate that the method does more than one thing and should be broken down into multiple methods.
- Unclear method or variable naming - A programmer should be able to understand what a method does without looking at the method's body. If the name or the parameter naming is indistinct, it is an indicator that the method should be refactored to reveal its purpose in the code.
More Information:
- Refactoring: Improving the Design of Existing Code - Kent Beck, Martin Fowler
- Clean Code: A Handbook of Agile Software Craftsmanship - Martin, Robert C. (2009).
- Code Smells on Wikipedia
- Code Smells on Jeff Atwood's Blog (Coding Horror)
- Code Smells on Ward Cunningham's C2 Wiki
- Martin Fowler - Code Smell