SRP-Single Responsibility Principle

C# Design Patterns and SOLID Principles SOLID Principles With Code Sample
11 minutes
Share the link to this page
Copied
  Completed
You need to have access to the item to view this lesson.
One-time Fee
$69.99
List Price:  $99.99
You save:  $30
€67.87
List Price:  €96.96
You save:  €29.09
£56.33
List Price:  £80.48
You save:  £24.14
CA$101.11
List Price:  CA$144.46
You save:  CA$43.34
A$112.90
List Price:  A$161.30
You save:  A$48.39
S$95.89
List Price:  S$136.99
You save:  S$41.10
HK$544.41
List Price:  HK$777.77
You save:  HK$233.35
CHF 63.59
List Price:  CHF 90.85
You save:  CHF 27.25
NOK kr795.45
List Price:  NOK kr1,136.41
You save:  NOK kr340.95
DKK kr506.37
List Price:  DKK kr723.41
You save:  DKK kr217.04
NZ$125.48
List Price:  NZ$179.27
You save:  NZ$53.78
د.إ257.07
List Price:  د.إ367.26
You save:  د.إ110.19
৳8,489.45
List Price:  ৳12,128.31
You save:  ৳3,638.85
₹6,003.32
List Price:  ₹8,576.54
You save:  ₹2,573.22
RM314.95
List Price:  RM449.95
You save:  RM135
₦108,169.08
List Price:  ₦154,533.88
You save:  ₦46,364.80
₨19,460.08
List Price:  ₨27,801.31
You save:  ₨8,341.22
฿2,414.58
List Price:  ฿3,449.55
You save:  ฿1,034.97
₺2,476.26
List Price:  ₺3,537.66
You save:  ₺1,061.40
B$432.69
List Price:  B$618.15
You save:  B$185.46
R1,309.65
List Price:  R1,871.01
You save:  R561.36
Лв132.94
List Price:  Лв189.93
You save:  Лв56.98
₩102,666.23
List Price:  ₩146,672.33
You save:  ₩44,006.10
₪255.59
List Price:  ₪365.15
You save:  ₪109.55
₱4,073.94
List Price:  ₱5,820.16
You save:  ₱1,746.22
¥11,002.07
List Price:  ¥15,717.92
You save:  ¥4,715.85
MX$1,443.99
List Price:  MX$2,062.93
You save:  MX$618.94
QR254.73
List Price:  QR363.91
You save:  QR109.18
P971.15
List Price:  P1,387.42
You save:  P416.26
KSh9,031.62
List Price:  KSh12,902.87
You save:  KSh3,871.24
E£3,551.78
List Price:  E£5,074.19
You save:  E£1,522.41
ብር8,922.62
List Price:  ብር12,747.15
You save:  ብር3,824.52
Kz63,830.88
List Price:  Kz91,190.88
You save:  Kz27,360
CLP$70,211.88
List Price:  CLP$100,306.99
You save:  CLP$30,095.10
CN¥512.36
List Price:  CN¥731.98
You save:  CN¥219.61
RD$4,268.13
List Price:  RD$6,097.60
You save:  RD$1,829.46
DA9,503.22
List Price:  DA13,576.62
You save:  DA4,073.39
FJ$162.81
List Price:  FJ$232.59
You save:  FJ$69.78
Q539.11
List Price:  Q770.19
You save:  Q231.08
GY$14,612.09
List Price:  GY$20,875.31
You save:  GY$6,263.22
ISK kr9,750.89
List Price:  ISK kr13,930.45
You save:  ISK kr4,179.55
DH704.78
List Price:  DH1,006.87
You save:  DH302.09
L1,300.73
List Price:  L1,858.26
You save:  L557.53
ден4,174.94
List Price:  ден5,964.46
You save:  ден1,789.51
MOP$559.86
List Price:  MOP$799.84
You save:  MOP$239.97
N$1,311.40
List Price:  N$1,873.51
You save:  N$562.11
C$2,571.06
List Price:  C$3,673.10
You save:  C$1,102.04
रु9,593.53
List Price:  रु13,705.64
You save:  रु4,112.10
S/262.27
List Price:  S/374.69
You save:  S/112.42
K279.90
List Price:  K399.88
You save:  K119.97
SAR262.85
List Price:  SAR375.52
You save:  SAR112.66
ZK1,946.04
List Price:  ZK2,780.17
You save:  ZK834.13
L337.70
List Price:  L482.45
You save:  L144.75
Kč1,708.24
List Price:  Kč2,440.45
You save:  Kč732.21
Ft28,222.76
List Price:  Ft40,319.96
You save:  Ft12,097.20
SEK kr777.78
List Price:  SEK kr1,111.16
You save:  SEK kr333.38
ARS$72,264.67
List Price:  ARS$103,239.67
You save:  ARS$30,975
Bs482.86
List Price:  Bs689.83
You save:  Bs206.97
COP$305,718.10
List Price:  COP$436,758.87
You save:  COP$131,040.76
₡35,617.57
List Price:  ₡50,884.43
You save:  ₡15,266.85
L1,775.85
List Price:  L2,537.04
You save:  L761.19
₲546,995.01
List Price:  ₲781,454.93
You save:  ₲234,459.92
$U3,074.18
List Price:  $U4,391.87
You save:  $U1,317.69
zł289.95
List Price:  zł414.23
You save:  zł124.28
Already have an account? Log In

Transcript

Okay, so now I guess you're ready to learn solid principles. And for that, without wasting time in theory at all, I would like to cover theory with code samples. So I'm just opening up with this video. And inside that we are going to create a new application. So for certifying that, I'm going to create a console app in dotnet framework. And let's say that we are going to give a meaningful name like the name of this application will be solid underscore P. Now this P stands for solid principles.

And the moment I click on OK, I hope you guys know that console application is the simplest application of dotnet framework. And ultimately, this is nothing but one simple EFC with only one class inside that with the name program.cs or something like that. So this is going to be a very simple console application right now. But step by step in this video series, I'm going to show you How we can write a code inside this by following all the principles available in this. So now we have a solid p which is having a program.cs inside that, which makes sense. Okay, it's just an empty class with a main method inside that for me, the first thing which I'm going to do is I'm going to right click on my solid p which is a console application, and I'm going to add a new C sharp class.

Now the name of the C sharp class I'm giving right now is invoice.cs. I'm just taking a scenario that assume that we are developing a software for an organization and this software is going to take care of invoice generation invoice printing, and all the calculations which are required for the invoice and all the declarations which are required for the invoice. Now inside this class invoice, the first thing which I'm going to do is I'm going to make sure that my graphics is whatever is going to be public, so that I can access this invoice class, anywhere. In this project and then inside this class we just have a simple logic like this. So you can check that I have an invoice class, which is having first two things like subtotal and tax rate. And if you know basics of object oriented programming concepts, I hope you know that these things are known as properties or even the better bodies automatic properties, because if you check subtotal and tax rate both are having a getter and setter inside this without any values.

So this is something which is known as automatic properties. And both the properties in my case are of type decimal. After these two properties, I have total three methods. So you can check the first method is calculate tax, which is returning decimal. And in that I'm just simply having a logic to do the calculation like subtotal multiply by tax rate divided by hundred. So that's what is going to give me a tax calculations.

And then we have another method which is calculate total, which is doing subtotal whatever Getting from that plus the method which is calculate tax we are calling here. So it's something like this that calculate tax is on the top. And we are calling it inside this calculate total. Finally, we have a third method, which is sprint, and the sprint is taking one parameter, which is of type invoice. So this is my class itself. And the sprint is not returning anything, it's just returning void.

And we do not have any logic right now inside the sprint, but I'm assuming that I'm going to have some logic of printing inside that which is right now not there in this code. Now, the question is, this is a very simple class and I hope you are able to understand the logic and the code which I have written inside that. So in this simple console application, I have a very simple class. And as we know, the first rule of solid principle is single responsibility principle. And to understand this principle, first of all you need to understand or you need to be smart to understand how many responses Release are there in a particular class. Like, for example, if I ask you that this class, which I have created right now is having a name invoice.

And this invoice class is having two properties and three methods inside that. If I asked you this question, how many responsibilities I have in this class? Or how many responsibilities this class is going to follow? What will be your answer? This class is having one single responsibility, two or three. This is something which I want an answer from your side.

Because this is that one of the thing where most people make mistake sometimes, if I ask people how many sponsors out there in this class, they answer that we have three responsibilities. They answer three because most of the time they focus on three different methods, and they count the number of public methods in the class. Each public method is going to count like a one responsibility and that's why we have three responsibilities. Sometime even a few guys who are not clear with this concept, they count the properties also as a responsibility, which is not exactly true. And that's why the right answer of this particular class is we have total two responsibilities. So the answer is, it's this invoice class is having two responsibilities.

One is this class is responsible for printing an invoice. And another one is this class responsible for calculate total. Now, I'm sure you want to ask me one question that why calculate tax is not a part of the responsibility. The reason is calculate tax is the method which is actually used inside calculate total. So this is not a separate responsibility. This is something which is a part of this.

And that's why we created that method. And we can call that thing here. Now, same way, right now, as I'm saying that this class is having two responsibilities. This is also possible that somewhere calculate total I'm going to call inside my print method. At that time, you The invoice class is only responsible for printing and all the other things are used inside that. So I just want to clarify one thing that when you try to understand this kind of class and the responsibilities do not focus only on number of public methods, please focus on the functionalities which are there in that particular class.

Or I can say the purpose which that class is solving. And that's where our single responsibility principle is going to come into the picture. Now, I asked you one question that how many responses are there in that particular class? But actually more than that question, there is one more question which is very, very, very important. The question which I want to ask you now is, what do you think, which is a better option? First, a class with only one responsibility, or a class with many responsibilities.

Now, before you answer this question, I just want to compare the scenario with one of the real life scenario like if you see online My screen, I have two different nights available. On the screen, the left side one is a Swiss knife, I'm sure you have seen a Swiss knife which has many functionalities inside that I can use the Swiss nine for different different purpose. And the right side we have a normal life which we use in our kitchen every day. And then based on that, we are going to use that knife only for one purpose which is cutting, cutting, cutting something. Now, if I ask you out of this two things, you just visualize that the right side one is a class with only one functionality, only one responsibility, which is a normal life. And the left side one is a class with many responsibilities and many functionalities inside that.

If I ask you, which is going to be more useful. I know there are a few guys who choose. So it's nice because it's having many purposes, but in real life as well as in the application also. The right answer is a thing which is only solving one focus Purpose is the one which is more useful. And if you don't agree with me just check one thing. If I asked you how many times in a month you're going to use a Swiss knife.

And if I asked you this question, I'm sure the answer is not so many times, most of us, we do not have a Swiss knife with us. And even if we have, we do not use it regularly, it's very rare to use a Swiss knife regularly. Even though it has many purposes, we never use that thing every day. While on the other hand, we have a normal life, which we use mostly everyday in our kitchen. Even though this is solving only one purpose, that is the one which is most useful. And very often we use that thing.

The same case is there in the application, also a class which is only solving one purpose, maybe going to be much more flexible and reusable inside the application in spite of the one class which is having many functionalities inside that. So the answer of this question is which is a better option. Obviously one class with only one responsibility inside that. And this is where I want to change my code a little bit now, to solve a purpose of a principle number one, let me go back to my Visual Studio. And inside this within studio as I know that I have an invoice class with FME two responsibilities. One responsibility is calculate total in which we are using this property and method.

And another responsibility is printing in which we do not have any logic right now. But now if I want to follow rule number one, which is single responsibility principle, I'm going to right click on my project, and I'm going to add a new C sharp class once again. And then maybe I'm giving a name of this class, invoice printer. The moment I given the name of this class invoice printer, this is a new class which is invoice printer, and I'm making sure that this class is also going to be public so that I can use it Anywhere. And then from this invoice class, I'm just going to do Ctrl x. For the sprint logic, I don't want that this logic is going to go inside that.

And inside of that, I'm going to put this sprint logic inside this. Now if you focus, I have two different C sharp classes in my project invoice.cs and invoice printer.cs invoice.cs is the class which is only dealing with the invoice calculation and the total, while the invoice printer is only focusing on the printer. And this is where we are satisfying rule number one, which is single responsibility principle. So now we have two different classes which only concerned about their own area of expertise, or I can say a domain logic. This one is also going to help us in the test driven development. I hope you know that nowadays most of the applications write unit test cases for the logic.

And if you have classes with the single responsibility that's also going to help you in TDD approach. And that's what the single responsivity principle is trying to tell you that you should be concerned about a single focus purpose for each class. And your class is going to only focus on one particular purpose. And that's why we are going to have only one responsibility. I hope you're able to understand Principle number one, and the do's and don'ts associated with this. It's time to move on to Principle number two now.

Thank you

Sign Up

Share

Share with friends, get 20% off
Invite your friends to LearnDesk learning marketplace. For each purchase they make, you get 20% off (upto $10) on your next purchase.