Skip to main content

SOLID principles

SOLID is an acronym that represents five design principles in object-oriented programming and software development. These principles were introduced by Robert C. Martin (also known as Uncle Bob) and are aimed at creating robust, maintainable, and scalable software systems. Each principle focuses on a specific aspect of software design and encourages developers to write code that is easy to understand, extend, and modify. Let's go through each of the SOLID principles:

Single Responsibility Principle (SRP):

The SRP states that a class should have only one reason to change, meaning it should have a single responsibility. In other words, a class should have one primary purpose or functionality, and it should not be responsible for more than that. This helps in keeping classes small, focused, and easier to maintain. When a class has multiple responsibilities, changes in one area can inadvertently affect other areas, leading to potential bugs and code entanglement.


Open/Closed Principle (OCP):


The OCP states that software entities (such as classes, modules, functions, etc.) should be open for extension but closed for modification. This means that you should be able to extend the behavior of a module or class without modifying its existing code. This can be achieved through the use of abstractions, interfaces, and inheritance, allowing you to add new features without changing the existing code, thus reducing the risk of introducing bugs in the existing functionality.


Liskov Substitution Principle (LSP):

The LSP states that objects of a superclass should be replaceable with objects of its subclasses without affecting the correctness of the program. In simpler terms, if a class A is a subclass of class B, then objects of class B should be able to be used interchangeably with objects of class A without altering the desired behavior of the system. This principle encourages the proper use of inheritance, avoiding situations where a subclass drastically changes the behavior of the superclass, leading to unexpected results.


Interface Segregation Principle (ISP):

The ISP states that a client should not be forced to depend on interfaces it does not use. In other words, instead of creating large, monolithic interfaces, it is better to create multiple smaller interfaces tailored to specific client needs. This allows clients to implement only the methods they require and prevents them from being burdened with unnecessary dependencies. This principle helps in reducing the impact of changes and promoting better encapsulation.


Dependency Inversion Principle (DIP):

The DIP states that high-level modules should not depend on low-level modules; both should depend on abstractions. Additionally, abstractions should not depend on details; details should depend on abstractions. This principle encourages the use of interfaces and dependency injection to decouple components within the system. By doing so, you can easily replace lower-level modules without affecting higher-level modules, making the codebase more flexible and maintainable.



By following the SOLID principles, developers can build more robust, maintainable, and extensible software systems, which are easier to understand, modify, and scale over time. These principles promote good coding practices and help in avoiding common design pitfalls.

Comments

Popular posts from this blog

Scrum - Transparency, Inspection , and Adaptation

What is Scrum ? Scrum is a light weight agile framework that helps people, organization and team to develop the software in iterative and incremental process. Three Pillars of Scrum Transparency - Giving visibility to the significant aspects of the process to those responsible for the outcome. Inspection - Timely checks on the progress toward a sprint goal to detect undesirable variances Adaptation - Adjusting process as soon as possible to minimize any further deviation or issues   These three pillars of the scrum is achieved through different ceremonies and artifacts of the scrum. We can map the pillars as follows Scrum Values  Scrum is built with following 5 values  Commitment - People personally commit to achieving the goals of the Scrum Team Focus - Everyone focuses on the work of the Sprint and the goals of the Scrum Team Openness - The scrum team and its stakeholders agree to be open about all the work and challenges to perform the work Respect - Scrum Team members respect