【设计模式】单一职责 开-闭 依赖倒转 里氏替换原则

几个设计模式的原则,简单了解了一下

单一职责

类的功能应该单一,就一个类而言,应该仅有一个引起它变化的原因,否则就要拆分。

【大话设计模式】里大鸟和小菜用的DV的摄像功能和手机的摄像功能的比较,DV的功能单一,手机的功能多而复杂,小菜在看到UFO的时候赶紧拿出手机来录像,结果发现录的很不清楚,如果是DV的话,小菜应该来得及摆一个牛逼的姿势,把UFO给录进去。

开闭原则

可以很简单的总结为一句话:对扩展开放,对修改关闭。

对一个功能的修改应该是通过增加代码的方式,而不是通过修改代码的方式。(内心独白:有时候需要一个函数来完成某个功能,不想修改原来的函数,那么就索性重载一个,这样算符合开闭原则么?)

小菜考研没有成功,也错过了校招的最好时机,于是他很蛋疼,大鸟用开闭原则告诉他:不影响考研复习的情况下(对修改关闭),拿出适当的时间去参加一下校招,投投简历(对扩展开放)。

大鸟还用邓爷爷的一国两制的例子来讲:即要对香港恢复行使主权的话,不能强制改变香港人的生活方式,毕竟在万恶的资本主义的铁蹄下生活了那么多年(把我送到资本主义去吧
让我去拯救他们吧!),所以基于tw问题提出的一国两制伟大构想,首先应用于HONGKONG,这就是对修改HK的社会制度关闭,在中国地区增加一个资本主义社会制度开放。

 依赖倒转原则

高层模块不应该依赖于底层模块,而都应该依赖于抽象。
抽象不应该依赖于细节,细节应该依赖于抽象。

对接口编程,而不是对实现编程。

以电脑主机为例,CPU, 内存, 硬盘, 光驱,
显卡等等这些设备都需要和主板相连,而相连的媒介是【接口】,他们和主板之间只需要符合接口标准就能通信。

不管什么品牌的设备,只要符合接口标准,就可以替换原来的设备,他们之间不需要关心其他设备是怎么制造的,用了什么工艺,什么技术等等,他们关心的只是接口。

精密的CPU,被封装成了一个小小的芯片,通过针脚连在主板上,主板对他一无所知。

 里氏替换原则

在软件中,父类能完成的功能,用子类来替换,软件的行为没有影响。

Animal *pAnimal = new Dog();

pAnimal->Craw();

把Dog类换成其他Cat类,其他程序地方不需要修改。

【设计模式】单一职责 开-闭 依赖倒转 里氏替换原则

时间: 2024-10-11 06:02:54

【设计模式】单一职责 开-闭 依赖倒转 里氏替换原则的相关文章

【设计模式之禅】第2章 里氏替换原则

引入里氏替换原则(LiskovSubstitution Principle,LSP)的目的就是为了解决继承中父子类之间产生的强耦合性. 2.1 爱恨纠葛的父子关系 继承 在面向对象的语言中,继承是必不可少的.非常优秀的语言机制 继承的优点 ● 代码共享,减少创建类的工作量,每个子类都拥有父类的方法和属性: ● 提高代码的重用性: ● 子类可以形似父类,但又异于父类,"龙生龙,凤生凤,老鼠生来会打洞"是说子拥有父的"种","世界上没有两片完全相同的叶子&qu

面向对象五大原则_1.单一职责原则&2.里氏替换原则

单一职责原则:Single Responsibility Principle (SRP) 一个类.仅仅有一个引起它变化的原因.应该仅仅有一个职责.每个职责都是变化的一个轴线.假设一个类有一个以上的职责,这些职责就耦合在了一起.这会导致脆弱的设计.当一个职责发生变化时,可能会影响其他的职责.另外,多个职责耦合在一起,会影响复用性. 比如:要实现逻辑和界面的分离. T负责两个不同的职责:职责P1.职责P2.当因为职责P1需求发生改变而须要改动类T时.有可能会导致原本执行正常的职责P2功能发生问题.

day01_面向对象五大原则_1.单一职责原则&2.里氏替换原则

单一职责原则:Single Responsibility Principle (SRP) 一个类,只有一个引起它变化的原因.应该只有一个职责.每一个职责都是变化的一个轴线,如果一个类有一个以上的职责,这些职责就耦合在了一起.这会导致脆弱的设计.当一个职责发生变化时,可能会影响其它的职责.另外,多个职责耦合在一起,会影响复用性.例如:要实现逻辑和界面的分离. T负责两个不同的职责:职责P1,职责P2.当由于职责P1需求发生改变而需要修改类T时,有可能会导致原本运行正常的职责P2功能发生故障.也就是

单一职能、开放封闭、里氏替换替换、接口隔离、依赖倒置

Object Oriented Design Principles Marla Sukesh, 8 Apr 2013    4.91 (155 votes) Rate this: vote 1vote 2vote 3vote 4vote 5   This article is intended for who have at least basic idea about Object oriented programming. Who is Audience? This article is i

C语言的设计模式-单一职责

C语言的设计模式-单一职责 单一职责原则: 通常的定义是只专注于做一件事和仅有一个引起它变化的原因.对于接口.实现.函数级别往往我们比较容易关注单一职责,大家谈的也比较多,但对于返回值.参数可能不会有太多的人关注.但往往就是这些不符合单一职责原则的设计可能导致一些很难发现的BUG.看看下面这段代码: pBuf = (byte*)realloc( pBuf, size); if( pbBuf != NULL ) { TODO... } 可能很多人一眼看上去并没有什么问题,先让我们看看这个库函数的定

C#设计模式系列:开闭原则(Open Close Principle)

1.开闭原则简介 开闭原则对扩展开放,对修改关闭,开闭原则是面向对象设计中可复用设计的基石. 2.开闭原则的实现 实现开闭原则的关键就在于抽象,把系统的所有可能的行为抽象成一个抽象底层,这个抽象底层规定出所有的具体实现必须提供的方法的特征.作为系统设计的抽象层,要预见所有可能的扩展,从而使得在任何扩展情况下,系统的抽象底层不需修改:同时,由于可以从抽象底层导出一个或多个新的具体实现,可以改变系统的行为,因此系统设计对扩展是开放的. 3.如何使用开闭原则 抽象约束 1>.通过接口或者抽象类约束扩展

设计模式的七大原则(4) --里氏替换原则

前言 上一节中我们介绍了,依赖倒置,依赖倒置利用抽象的稳定性来架构我们的系统,是我们经常能遇到的一种原则,比如说面向接口编程. 这一节中,我们来说说里氏替换原则,这个原则其实非常非常的简单,其实与依赖倒置相结合来看,就是希望我们用抽象的方法来构建项目而非具体的实现,里氏替换原则就是推荐我们不要重写父类中具体的实现来构建我们的项目. 我们来深入研究研究. 基本介绍 继承包含这样一层含义:父类中凡是已经实现好的方法,实际上是在设定规范和契约,虽然它不强制要求所有的子类必须遵循这些契约,但是如果子类对

学习设计模式 - 六大基本原则之里氏替换原则

设计模式总共有六大基本原则,统称为SOLID (稳定)原则,分别是S-单一职责原则(Single Responsibility Principle), O-开闭原则(Open closed Principle),L-里氏替换原则(Liskov Substitution Principle),L-迪米特法则(Law of Demeter),I-接口隔离原则(Interface Segregation Principle),D-依赖倒置原则(Dependence Invension Principl

依赖注入的本质与里氏替换原则

根据开闭原则或(依赖倒置原则)控制翻转原则建立了稳定的抽象层. 抽象层中的抽象组件(元素)不能实例化,需要在运行时用子类对象进行替代. 这个抽象组件被替代的过程就是依赖注入. 依赖注入解决的是如何用子类替代父类的问题. 里氏替换原则,OCP作为OO的高层原则,主张使用“抽象(Abstraction)”和“多态(Polymorphism)”将设计中的静态结构改为动态结构,维持设计的封闭性.“抽象”是语言提供的功能.“多态”由继承语义实现. 里氏替换原则中说,任何基类可以出现的地方,子类一定可以出现