Single Responsibility Principle
Single Responsibility Principle
The Single Responsibility Principle (SRP) states that a class should have only one reason to change. It was first cited in this form by Robert C. Martin in an article that later formed a chapter in his Principles, Patterns, and Practices of Agile Software Development book.
The Single Responsibility Principle is closely related to the concepts of coupling and cohesion. Coupling refers to how inextricably linked different aspects of an application are, while cohesion refers to how closely related the contents of a particular class or package may be. All of the contents of a single class are tightly coupled together, since the class itself is a single unit that must either be entirely used or not at all (discounting static methods and data for the moment). When other classes make use of a particular class, and that class changes, the depending classes must be tested to ensure they continue to function correctly with the new behavior of the class. If a class has poor cohesion, some part of it may change that only certain depending classes utilize, while the rest of it may remain unchanged. Nonetheless, classes that depend on the class must all be retested as a result of the change, increasing the total surface area of the application that is affected by the change. If instead the class were broken up into several, highly cohesive classes, each would be used by fewer other elements of the system, and so a change to any one of them would have a lesser impact on the total system.
Martin suggests that we define each responsibility of a class as a reason for change. If you can think of more than one motivation for changing a class, it probably has more than one responsibility. When these axes of change occur, the class will probably need to have different aspects of its behavior changed, at different times and for different reasons. However, like other principles, it's unwise to try and apply SRP to everything from the outset. If a particular class is stable and isn't causing needless pain as a result of changes, there is little need to change it. Practice Pain Driven Development.
Some examples of responsibilities to consider that may need to be separated include:
- Error Handling
- Class Selection / Instantiation
Just listened to @ardalis talk about the Single Responsibility Principle in his new course, nicely done Steve.— Aaron Skonnard (@skonnard) September 10, 2010
This class violates both Single Responsibility Principle and Open/Closed Principle. Not surprisingly, I've run into issue modifying it.— Jonathan Hammond (@Hamman359) March 18, 2011
We dislike long methods, but they're symptoms of bigger problems—lack of single responsibility, poor abstraction, high coupling.— Venkat Subramaniam (@venkat_s) October 9, 2011
If you grok only one of the SOLID principles, make it Single Responsibility Principle. Everything else flows from that.— Will “WEAR A DAMN MASK” (@hotgazpacho) October 20, 2011
Few people realize that the single responsibility principle and the open/closed principle are the same thing.— Michael Feathers (@mfeathers) July 23, 2013
Single Responsibility Principle (Wikipedia)
SOLID Principles of Object Oriented Design - Pluralsight - Steve SmithEdit this page on GitHub