什么是SOLID


Posted in Javascript onMarch 24, 2022

S.O.L.I.D是面向对象设计和编程(OOD&OOP)中几个重要编码原则(Programming Priciple)的首字母缩写。

SRP The Single Responsibility Principle 单一责任原则
OCP The Open Closed Principle 开放封闭原则
LSP The Liskov Substitution Principle 里氏替换原则
ISP The Interface Segregation Principle 接口分离原则
DIP The Dependency Inversion Principle 依赖倒置原则

简写 全拼 中文
SRP The Single Responsibility Principle 单一责任原则
OCP The Open Closed Principle 开放封闭原则
LSP The Liskov Substitution Principle 里氏替换原则
ISP The Interface Segregation Principle 接口分离原则
DIP The Dependency Inversion Principle 依赖倒置原则

1. 单一责任原则(SRP)

当需要修改某个类的时候原因有且只有一个。换句话说就是让一个类只做一种类型责任,当这个类需要承当其他类型的责任的时候,就需要分解这个类。 类被修改的几率很大,因此应该专注于单一的功能。如果你把多个功能放在同一个类中,功能之间就形成了关联,改变其中一个功能,有可能中止另一个功能,这时就需要新一轮的测试来避免可能出现的问题,非常耗时耗力。

2. 开放封闭原则(OCP)

软件实体应该是可扩展,而不可修改的。也就是说,对扩展是开放的,而对修改是封闭的。这个原则是诸多面向对象编程原则中最抽象、最难理解的一个。

(1)通过增加代码来扩展功能,而不是修改已经存在的代码。
(2)若客户模块和服务模块遵循同一个接口来设计,则客户模块可以不关心服务模块的类型,服务模块可以方便扩展服务(代码)。
(3)OCP支持替换的服务,而不用修改客户模块。

如果现在又多了一种发送信息的方式,比如可以通过QQ发送信息,那么不仅需要增加一个方法sendByQQ(),还需要在调用它的地方进行修改,违反了OCP原则,更好的方式是

抽象出一个Send接口,里面有个send()方法,然后让SendByEmail和SendBySMS去实现它既可。这样即使多了一个通过QQ发送的请求,那么只要再添加一个SendByQQ实现类实现Send接口既可。这样就不需要修改已有的接口定义和已实现类,很好的遵循了OCP原则。

3. 里氏替换原则(LSP)

任何基类可以出现的地方,子类一定可以出现。
当一个子类的实例应该能够替换任何其超类的实例时,它们之间才具有is-A关系

客户模块不应关心服务模块的是如何工作的;同样的接口模块之间,可以在不知道服务模块代码的情况下,进行替换。即接口或父类出现的地方,实现接口的类或子类可以代入。

4.接口分离原则

接口分离原则指在设计时采用多个与特定客户类有关的接口比采用一个通用的接口要好。即,一个类要给多个客户使用,那么可以为每个客户创建一个接口,然后这个类实现所有的接口;而不要只创建一个接口,其中包含所有客户类需要的方法,然后这个类实现这个接口。
没有使用接口分离原理的设计如图1-1所示,存在以下问题:如果Client A类需要改变所使用的Service接口中的方法,那么不但要改动Service接口和ServiceImp类,还要对ClientB类和ClientC类重新编译。也就是说,对ClientA的修改会影响ClientB和ClientC,因此应对其进行修改。

使用通用接口设计
什么是SOLID

使用接口分离设计
什么是SOLID

5. 依赖注入或倒置原则(DIP)

  1. 高层模块不应该依赖于低层模块,二者都应该依赖于抽象
  2. 抽象不应该依赖于细节,细节应该依赖于抽象

这个设计原则的亮点在于任何被DI框架注入的类很容易用mock对象进行测试和维护,因为对象创建代码集中在框架中,客户端代码也不混乱。有很多方式可以实现依赖倒置,比如像AspectJ等的AOP(Aspect Oriented programming)框架使用的字节码技术,或Spring框架使用的代理等。

(1).高层模块不要依赖低层模块;
(2).高层和低层模块都要依赖于抽象;
(3).抽象不要依赖于具体实现;
(4).具体实现要依赖于抽象;
(5).抽象和接口使模块之间的依赖分离。

http://www.cnblogs.com/lanxuezaipiao/archive/2013/06/09/3128665.html

Javascript 相关文章推荐
js window.event对象详尽解析
Feb 17 Javascript
深入理解JavaScript系列(37):设计模式之享元模式详解
Mar 04 Javascript
js实现从右向左缓缓浮出网页浮动层广告的方法
May 09 Javascript
JavaScript实现阿拉伯数字和中文数字互相转换
Jun 12 Javascript
js实现动态显示时间效果
Mar 06 Javascript
BootStrap Fileinput上传插件使用实例代码
Jul 28 Javascript
vue做网页开场视频的实例代码
Oct 20 Javascript
vue axios 二次封装的示例代码
Dec 08 Javascript
解决mpvue + vuex 开发微信小程序vuex辅助函数mapState、mapGetters不可用问题
Aug 03 Javascript
用图片替换checkbox原始样式并实现同样的功能
Nov 15 Javascript
详解jQuery中的getAll()和cleanData()
Apr 15 jQuery
javascript实现简单页面倒计时
Mar 02 Javascript
Vue3中toRef与toRefs的区别
Mar 24 #Vue.js
Javascript的promise,async和await的区别详解
Mar 24 #Javascript
一起来看看Vue的核心原理剖析
Mar 24 #Vue.js
手写Spirit防抖函数underscore和节流函数lodash
Mar 22 #Javascript
深入讲解Vue中父子组件通信与事件触发
Mar 22 #Vue.js
关于Vue中的options选项
Mar 22 #Vue.js
vue+echarts实现多条折线图
You might like
PHP6 先修班 JSON实例代码
2008/08/23 PHP
PHP下利用header()函数设置浏览器缓存的代码
2010/09/01 PHP
php 使用file_get_contents读取大文件的方法
2014/11/13 PHP
PHP判断JSON对象是否存在的方法(推荐)
2016/07/06 PHP
javascript延时重复执行函数 lLoopRun.js
2007/06/29 Javascript
用apply让javascript函数仅执行一次的代码
2010/06/27 Javascript
jQuery Ajax 仿AjaxPro.Utility.RegisterTypeForAjax辅助方法
2011/09/27 Javascript
js禁止页面复制功能禁用页面右键菜单示例代码
2013/08/29 Javascript
Bootstrap基本样式学习笔记之标签(5)
2016/12/07 Javascript
如何使用Bootstrap创建表单
2017/03/29 Javascript
vue上传图片组件编写代码
2017/07/26 Javascript
AngularJS中控制器函数的定义与使用方法示例
2017/10/10 Javascript
vue-cli项目代理proxyTable配置exclude的方法
2018/09/20 Javascript
electron制作仿制qq聊天界面的示例代码
2018/11/26 Javascript
js实现京东秒杀倒计时功能
2019/01/21 Javascript
JS实现计算小于非负数n的素数的数量算法示例
2019/02/26 Javascript
使用layui实现的左侧菜单栏以及动态操作tab项方法
2019/09/10 Javascript
JS+DIV实现拖动效果
2020/02/11 Javascript
JS实现页面数据懒加载
2020/02/13 Javascript
vue实现公告栏文字上下滚动效果的示例代码
2020/06/16 Javascript
Json实现传值到后台代码实例
2020/06/30 Javascript
微信小程序学习之自定义滚动弹窗
2020/12/20 Javascript
[47:03]Ti4第二日主赛事败者组 LGD vs iG 2
2014/07/21 DOTA
Python常用内置函数总结
2015/02/08 Python
Python中执行存储过程及获取存储过程返回值的方法
2017/10/07 Python
Python基于datetime或time模块分别获取当前时间戳的方法实例
2019/02/19 Python
Python环境Pillow( PIL )图像处理工具使用解析
2019/09/12 Python
python实现LRU热点缓存及原理
2019/10/29 Python
flask开启多线程的具体方法
2020/08/02 Python
python PyAUtoGUI库实现自动化控制鼠标键盘
2020/09/09 Python
科颜氏法国官网:Kiehl’s法国
2019/08/20 全球购物
介绍一下Mysql的存储引擎
2015/02/12 面试题
医学护理系毕业生求职信
2013/10/01 职场文书
销售心得体会
2014/01/02 职场文书
职务说明书范文
2014/05/07 职场文书
小学毕业感言100字
2015/07/30 职场文书