设计模式之禅——设计原则SOLID+D(读书笔记)

设计原则-SOLID+D

设计是有限度的,不能无限的考虑未来的变更情况,否则就会陷入设计的泥潭中而不能自拔

- S单一职责原则Single Responsibility Principle,SRP

定义: 应该有且仅有一个原因引起类的变更。

单一职责原则要求一个接口或类只有一个原因引起变化,也就是一个接口或类只有一个职责,它就负责一件事情。

优点:

  • 类的复杂性降低,实现什么职责都有清晰明确的定义;
  • 可读性提高;
  • 可维护性提高;
  • 变更引起的风险降低,变更时必不可少的,如果接口的单一职责做得好,一个接口修改只对相应的实现类有影响,对其他的接口无影响,这对系统的扩展性、维护性都有很大的帮助。

- O开闭原则Open Closed Principle,ocp

定义:软件实体应该对扩展开放,对修改关闭,其含义是说一个软件实体应该通过扩展来实现变化,而不是通过修改已有的代码来实现变化。

开闭原则是Java世界里最基础的设计原则,它指导我们如何建立一人稳定的、灵活的系统。

开闭原则告诉我们应该尽量通过扩展软件实体的行为来实现变化而不是通过修改已有的代码来完成变化,它是为软件实体的未来时间而定制的对现行开发设计进行约束的一个原则。

开闭原则是抽象类,其他的原则是具体的实现类。

优点:

  • 开闭原则对测试的影响:只需要保证新增类的正确性,不需要修改原来代码;
  • 提高复用性:所有的逻辑是从原子逻辑组合而来的,而不是一个类中独立实现一个业务逻辑。这样代码才可以复用。复用减少代码量,避免相同的逻辑分散在多个角落,避免日后维护人员为了修改一个微小的缺陷或增加新功能而要在项目中到处查找相关代码;
  • 开闭原则提高复用性:扩展的时候不需要维护原有类;
  • 应对面向对象开发的要求:抽象接口;

- L里氏替换原则Liskov Substitution Principle,LSP

定义:只要父类能出现的地方子类就能够出现,而且替换为子类也不会产生任何错误或异常,使用者可能根本就不需要指导是父类还是子类。但是,反过来就不行了,有子类出现的地方,父类未必能适应。

规范:

  1. 子类必须完全实现父类的方法。如果子类不能完整的实现父类的方法,或者父类的某些方法在子类中已经发生畸变,则建议断开父子继承关系,采用依赖、聚集、组合等关系代替。
  2. 子类可以有自己的个性。
  3. 覆盖或实现父类的方法时输入参数可以被放大。利用重载实现。
  4. 覆写或实现父类的方法时输出结果可以被缩小。

优点: 面向对象的语言中,继承是必不可少的,具有代码共享、多态、扩展性等优点,但是也增强了耦合性,降低了灵活性,所以需要里氏替换原则减少弊端,发挥优点。

- I接口隔离原则Interface Segregation Principle

定义:客户端不该依赖他不需要的接口,类间的依赖关系应该建立在最小的接口上。

建立单一接口,不要建立庞大臃肿的接口

接口分类:

  • 实例接口:Java中的类也是一种接口
  • 类接口:interface关键字定义的接口

接口隔离原则与单一职责原则是不一样的:接口隔离原则与单一职责的审视角度是不相同的,单一职责要求的是类和接口职责单一,注重的是职责,这是业务逻辑上的划分,而接口隔离原则要求接口的方法尽量少。

接口隔离原则是对接口进行规范约束:

  1. 接口要尽量小。根据接口隔离原则拆分接口时,首先必须满足单一职责原则;
  2. 接口要高内聚。接口中尽量少公布public方法,接口是对外的承诺,承诺越少对系统的开发越有利,变更的风险也越少,同时也有利于降低成本;
  3. 定制服务。拆分接口,只提供个体需要的服务;
  4. 接口设计是有限度的;

最佳实践:

  • 一个接口只服务于一个子模块或业务逻辑;
  • 通过业务逻辑压缩接口中的public方法;
  • 已经被污染的接口,尽量去修改,若变更的风险较大,则采用适配器模式进行转化处理; 了解环境,拒绝盲从。

- D依赖倒置原则Dependence Inversion Principle,DIP

含义:

  • 高层模块不应该依赖低层模块,两者都应该依赖其抽象;
  • 抽象不应该依赖细节;
  • 细节应该依赖抽象;

表现:

  • 模块间的依赖通过抽象发生,实现类之间不发生直接的依赖关系,其依赖关系是通过接口或抽象类产生的;
  • 接口或抽象不依赖于实现类;
  • 实现类依赖接口或抽象类。

面向接口编程

采取依赖倒置原则可以减少类间的耦合性,提高系统的稳定性,降低并行开发引起的风险,提高代码的可读性和可维护性。

抽象是对实现的约束,对依赖着而言,也是一种契约,不仅仅约束自己,还同时约束自己与外部的关系,其目的是保证所有的细节不脱离契约的范畴,确保约束双方按照既定的契约共同发展。 最佳实践:

  • 每个类尽量都有接口或抽象类,或者抽象类和接口都具备;
  • 变量的表面类型尽量是接口或者是抽象类;
  • 任何类都不该从具体类派生
  • 尽量不要覆写基类的方法;
  • 结合里氏替换原则使用。

- D迪米特法则Law of Demeter,LOD

定义:应该对其他对象有最少的了解。

迪米特法则的核心观念就是类间解耦,弱耦合,只有弱耦合之后,类的复用率才可以提高。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352