面象对象设计6大原则之一:单一职责原则

简介: 单一职责原则(SRP),The Single Responsibility Principle定义一个类的修改只能有一个被修改的原因。

单一职责原则(SRP),The Single Responsibility Principle

定义

一个类的修改只能有一个被修改的原因。

通俗地讲,就是一个类只能负责一个职责,修改一个类不能影响到别的功能,也就是说只有一个导致该类被修改的原因。我们写代码的都知道尽量要做到低耦合、高内聚的特性,单一职责原则正是保证了类与类之间的低耦合性。一个类如果承担过多的职责,就会有很多原因来导致这个类的被修改,就有很大可能性影响到别的功能。

单一职责原则,看起来是一个非常简单的原则,但真正实践起来也并非易事,因为职责的联合在实际当中是经常遇到的事,也不能随便地去拆分类去适配单一职责模式,所以如何从这些联合的职责中合理地把职责分隔出来更合适的遵守单一职责原则要好好考虑。

看看下面这这个接口是否符合单一职责原则呢?

public interfaceUserInterface{

voidsaveUser(User user);

UsergetUser(long id);

voidupdateUserBalance(long id, BigDecimal balance);

BigDecimalgetUserBalance(long id);

}

这是一个用户接口,提供四个方法:保存用户、获取用户、更新用户余额、获取用户余额,很显然用户个人信息与用户的账户余额是两回事,这样设计在一起耦合非常高,不利于扩展,也不符合单一职责原则,我们可以把它折分成两个,一个为用户信息接口,一个账户接口,如下

public interfaceUserInterface{

voidsaveUser(User user);

UsergetUser(long id);

}

public interfaceAccountInterface{

voidupdateUserBalance(long id, BigDecimal balance);

BigDecimalgetUserBalance(long id);

}

这样分开来,是不是就符合了单一职责原则,类的复杂性和耦合性也降低了,即使用户接口或账户接口加减接口也不影响别的接口实现类。

所以,单一职责原则可以总结为以下优势:

1、低耦合性,影响范围小。

2、类复杂度降低,职责分明,提高了可读性。

3、职责单一,利于维护。

相关文章
|
6月前
|
设计模式 存储 Java
JAVA设计模式11:组合模式,以统一的方式处理单个对象和组合对象
JAVA设计模式11:组合模式,以统一的方式处理单个对象和组合对象
|
设计模式 算法 Java
六大原则之外的设计原则|设计原则
在前面的几篇设计原则文章中,我们分别讲述了经典的六大设计原则。但是事实上,我们在开发中还有几个重要的设计原则,在这篇文章中,一并给大家讲述。
|
设计模式 uml
设计模式七大原则——合成复用原则
设计模式七大原则——合成复用原则
设计模式七大原则——合成复用原则
面向对象基本原则(1)- 单一职责原则与接口隔离原则
面向对象基本原则(1)- 单一职责原则与接口隔离原则 面向对象基本原则(2)- 里式代换原则与依赖倒置原则 面向对象基本原则(3)- 最少知道原则与开闭原则
|
设计模式 安全 Python
设计模式中应遵循的基本原则
设计模式中应遵循的基本原则
176 0
|
设计模式
【设计模式】软件设计七大原则 ( 里氏替换原则 | 定义 | 定义扩展 | 引申 | 意义 | 优点 )
【设计模式】软件设计七大原则 ( 里氏替换原则 | 定义 | 定义扩展 | 引申 | 意义 | 优点 )
167 0
|
设计模式 存储
【设计模式】享元模式 实现 ( 实现流程 | 抽象享元类 | 具体享元类 | 享元工厂 | 用户调用 | 代码模板 )
【设计模式】享元模式 实现 ( 实现流程 | 抽象享元类 | 具体享元类 | 享元工厂 | 用户调用 | 代码模板 )
162 0
|
设计模式 数据可视化 C#
【愚公系列】2021年12月 通用职责分配原则(六)-多态原则(Polymorphism Principle)
【愚公系列】2021年12月 通用职责分配原则(六)-多态原则(Polymorphism Principle)
|
Spring Java
面象对象设计6大原则之四:接口隔离原则
接口隔离原则(ISP),The Interface Segregation Principle 定义 客户端不需要强迫依赖那些它们不需要的接口。
1017 0