Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >单一职责原则

单一职责原则

作者头像
LieBrother
发布于 2019-04-02 08:20:50
发布于 2019-04-02 08:20:50
3950
举报
文章被收录于专栏:LieBrotherLieBrother

设计模式六大原则之一:单一职责原则

简介

姓名 :单一职责原则

英文名 :Single Responsibility Principle

座右铭 :There should never be more than one reason for a class to change. 应当有且仅有一个原因引起类的变更。。。意思就是不管干啥,我都只干一件事,你叫我去买菜,我就只买菜,叫我顺便去倒垃圾就不干了,就这么拽

脾气 :一个字“拽”,两个字“特拽”

伴侣 :老子职责单一,哪来的伴侣?

个人介绍 :在这个人兼多责的社会里,我显得那么的特立独行,殊不知,现在社会上发生的很多事情都是因为没有处理好职责导致的,比如,经常有些父母带着小孩,一边玩手机,导致小孩弄丢、发生事故等等

单一职责应用范围

单一职责原则适用的范围有接口、方法、类。按大家的说法,接口和方法必须保证单一职责,类就不必保证,只要符合业务就行。

方法

设想一下这个场景:假设我们要做一个用户修改名字以及修改密码的功能,可以有多种实现方案,比如下面列举 2 种实现方式

代码:

https://github.com/1CSH1/DesignPatterns/blob/master/src/com/liebrother/designpatterns/srp/SrpOfMethod.java

第一种实现方式

第二种实现方式

2 种实现有什么区别呢? 第一种实现通过 OprType 类型的不同来做不同的事情,把修改密码和修改名字耦合在一起,容易引起问题,只要稍不注意,传错枚举值就悲剧了,在代码中也没法很直接看到是做什么操作,也就是这个方法的职责不明确。而第二种实现,把修改密码和修改名字分离开来,也就是把修改密码和修改名字都当做独自的职责处理,这样子就很清晰明了,你调用哪个方法,就很明确的知道这个方法是实现什么逻辑。结论是啥呢?用第二种方式实习才符合单一职责原则。现实中看到很多像第一种实现的代码,而且是枚举有十来个的情况,看代码真费劲。

接口

设想一下这个场景,假设我们让小明去倒垃圾,小红去买菜,小红回来后再叫小红去洗碗。下面也举 2 个实现的例子。

代码:

https://github.com/1CSH1/DesignPatterns/blob/master/src/com/liebrother/designpatterns/srp/SrpOfInterface.java

第一种实现方式

中途回来小红去洗碗,要怎么实现?按这个写法,就在 Housework 接口添加 washingUp() 方法,然后小明和小红依次都实现洗碗这个方法,只是小明不做具体实现代码,这样子是不是觉得很别扭,不符合单一职责原则的,修改一个地方,不影响其他不需要改变的地方,只对需要用到的地方做修改。小明本来就不用洗碗,却要去实现洗碗这个方法。

第二种实现方式

可以看到,这种实现把不同的家务都当做不同的职责,分离开来,这种实现可以按需实现做家务的类型,小明只需要去倒垃圾,就实现 PourGarbage 接口,小红去购物和洗碗,就实现 Shopping 和 WashingUp 接口,完全不会影响到对方,这才是完美的根据单一职责原则编写出来的代码。

类这个看了一些资料都说没法硬性要求一定按单一职责原则分,或者说类的职责可大可小,没有很明确的像上面接口那样按照单一职责原则分就很清晰也很有道理。

设想一下这个场景:我们要实现一个用户注册、登录、注销操作,可以像如下 2 种实现方式

代码:

https://github.com/1CSH1/DesignPatterns/blob/master/src/com/liebrother/designpatterns/srp/SrpOfClass.java

第一种实现方式

从用户的角度考虑,这些操作都是用户的行为,可以放在一个统一的类 UserBiz

第二种实现方式

有人又说,不是说单一职责么?从业务操作考虑,需要把注册、登录、注销分开

感觉像是在抬杠,其实这个没有好坏之分,根据具体业务具体分析,你说你的登录、注册、注销操作代码很多,需要分开,那就分开,无可厚非。

好处

1. 类的复杂性降低,实现什么职责都有清晰明确的定义

2. 可读性提高,复杂性降低,那当然可读性提高了

3. 可维护性提高,可读性提高,那当然更容易维护了

4. 变更引起的风险降低,变更是必不可少的,如果接口的单一职责做得好,一个接口修改只对相应的实现类有影响,对其他的接口无影响,这对系统的扩展性、维护性都有非常大的帮助

(来自《设计模式之禅》)

总结

这个单一职责原则,目的就是提高代码的可维护性、可读性、扩展性,如果为了单一职责而破坏了这 3 个特性,可能会得不偿失。

参考资料

《大话设计模式》、《Java设计模式》、《设计模式之禅》、《研磨设计模式》、《Head First 设计模式》

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-12-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 LieBrother 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
02.单一职责原则详解
设计模式Git项目地址:https://github.com/yangchong211/YCDesignBlog
杨充
2024/12/26
1540
设计模式六大原则(一)----单一职责原则
就一个类而言,应该仅有一个引起它变化的原因。应该只有一个职责。如果一个类有一个以上的职责,这些职责就耦合在了一起。一个职责的变化可能会削弱或者抑制这个类完成其他职责的能力。这会导致脆弱的设计。当一个职责发生变化时,可能会影响其它的职责。另外,多个职责耦合在一起,会影响复用性。想要避免这种现象的发生,就要尽可能的遵守单一职责原则。
用户7798898
2021/06/10
3.9K0
单一职责原则
本系列文章从场景代码入手,通过代码review指出当前存在的问题,然后思考改进,最后进行提炼总结,即通过”代码-问题-改进-总结“的方式学习编程模式,感受思考的乐趣,To be a better coder.
数据小冰
2022/08/15
3430
单一职责原则
设计模式|理解单一职责原则
很早想总结一些关于设计模式的文章了,回头看一下几年前写的代码,简直不忍直视。也能理解,毕竟当初校招选择测试岗位也是为了逃避“写代码”嘛,但是谁能想到,当下测试行业大环境,不会编程的测试简直无法生存。亏我的思想觉悟比较高,认识到编程的重要性后就狂补了一些开发“基础”,例如Java、spring mvc这些知识,不能说专业吧,最起码也是运用自如,能实现自己的ideas。
互联网金融打杂
2022/08/01
2640
设计模式|理解单一职责原则
设计模式—— 一:单一职责原则
单一职责原则的英文名称是Single Responsibility Principle,简称是SRP。
三分恶
2020/07/16
5370
设计模式-单一职责原则
设计模式有六大基本原则,单一职责原则,里氏替换原则,依赖倒置原则,接口隔离原则,迪米特法则,开闭原则。
mySoul
2018/11/16
8780
面向对象的设计原则-"单一职责原则"
Single Responsibility Principle SRP,"单一职责原则":一个类只负责一组相关的事情,对应到代码中就是:一个类有多个方法,这些方法时相关的。
别明天就今天吧
2020/09/07
7470
小谈设计模式(4)—单一职责原则
主要对目前市面上常见的23种设计模式进行逐一分析和总结,希望有兴趣的小伙伴们可以看一下,会持续更新的。希望各位可以监督我,我们一起学习进步,加油,各位。
学编程的小程
2023/10/11
3330
小谈设计模式(4)—单一职责原则
单一职责原则
单一职责原则的英文是 Single Responsibility Principle,缩写为 SRP。一个类或者模块只负责完成一个职责(或者功能)。
Yuyy
2022/09/21
5250
设计模式六大原则(一)--单一职责原则
单一职责原则是设计模式六大原则之一,强调一个类应该仅有一个引起它变化的原因,即每个类应仅负责一项职责。本文通过详细探讨单一职责原则的定义、实现方式、优缺点及其适用场景,揭示了其在软件设计中的核心地位。通过类的拆分、接口设计和方法提炼等策略,单一职责原则有助于降低类的复杂度,提高代码的可读性、可维护性和可扩展性。尽管过度应用可能导致类的数量增加和系统复杂性提升,但其在大型项目和复杂系统中的长期效益显著。
小白的大数据之旅
2024/11/20
2510
设计模式六大原则(一)--单一职责原则
面象对象设计6大原则之一:单一职责原则
单一职责原则(SRP),The Single Responsibility Principle 定义 一个类的修改只能有一个被修改的原因。 通俗地讲,就是一个类只能负责一个职责,修改一个类不能影响到别的功能,也就是说只有一个导致该类被修改的原因。我们写代码的都知道尽量要做到低耦合、高内聚的特性,单一职责原则正是保证了类与类之间的低耦合性。一个类如果承担过多的职责,就会有很多原因来导致这个类的被修改,就有很大可能性影响到别的功能。 单一职责原则,看起来是一个非常简单的原则,但真正实践起来也并非易事,因为职
Java技术栈
2018/03/30
5050
如何使用单一职责原则
类的职责也不是越单一越好,还是要考虑扩展性、可读性等,所有设计原则的目的瓯都市为了实现代码高内聚、低耦合,提高代码的复用性、可读性、可维护性。
十毛
2022/01/12
2200
单一职责原则(SRP)
单一职责原则(英文名为Single Responsibility Principle,简称SRP)是Robert C. Martin提出的SOLID软件设计原则中的第一个字母S。
河边一枝柳
2022/06/21
6400
单一职责原则(SRP)
依赖倒置原则
1. High level modules should not depend upon low level modules.Both should depend upon abstractions. 高层模块不应该依赖低层模块,两者都应该依赖其抽象(模块间的依赖通过抽象发生,实现类之间不发生直接的依赖关系,其依赖关系是通过接口或抽象类产生的)
LieBrother
2019/03/29
6770
依赖倒置原则
设计原则之单一职责原则(SRP)
单一职责原则是最重要的设计原则,也是最抽象的设计原则。小到函数,大到平台的设计,都可以使用单一职责原则来指导。也正因为它的抽象性,没有一个统一的规则,不同的人即使是设计同一个功能,所划分的函数、类也都是不相同的。
Dylan Liu
2019/07/01
9660
设计模式看了又忘,忘了又看?
耗时了 5 个月,终于把设计模式一整个系列写完。其实设计模式这一系列文章网上已经有很多非常好、非常优秀的文章,为什么要写呢?
LieBrother
2019/05/29
7560
设计模式看了又忘,忘了又看?
探讨单一职责原则与方法组合的界线
单一职责原则(Single Responsibility Principle, SRP)是软件工程中的重要设计原则之一,它强调一个类或方法应该只有一个变化的原因。换句话说,每个类或方法应只负责单一的职责。然而,在实际的代码设计中,如何将多个方法组合成一个功能的方法,同时又不违背单一职责原则,是值得深思的问题。在本文中,我们将尝试探讨这个问题,并分析在何种情况下方法的组合与单一职责原则之间的关系。
运维开发王义杰
2023/10/08
3050
探讨单一职责原则与方法组合的界线
单一职责原则(Single Responsibility Principle,SRP)
1 简介 1.1 定义 不要存在多于一个导致类变更的原因。该原则备受争议,争议之处在于对职责的定义,什么是类的职责?怎么划分类的职责? 1.2 特点 一个类/接口/方法只负责一项职责。 1.3 优点
JavaEdge
2021/02/22
6660
6大设计原则之单一职责原则
我想,任谁也能看的出这个接口设计的有问题,用户的属性和用户的行为没有分开,应该把用户的信息抽取成一个业务对象,把用户的行为抽取成一个业务对象,按照这个思路对类图进行修正,如下图所示
烟草的香味
2019/07/25
3710
10年+ .NET Coder 心语 ── 单一职责原则的思维:为什么你的代码总在"牵一发而动全身"
在编程的世界里,面向对象设计(Object-Oriented Design, OOD)就像盖房子时打下的地基,决定了一个系统是否稳固、耐用。而在众多设计原则中,单一职责原则(Single Responsibility Principle, SRP) 无疑是那块最坚实的基石。它不仅指导我们如何编写清晰的代码,还在某种程度上映射了生活中处理复杂问题的智慧。
AI.NET 极客圈
2025/05/27
850
10年+ .NET Coder 心语 ── 单一职责原则的思维:为什么你的代码总在"牵一发而动全身"
相关推荐
02.单一职责原则详解
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档