设计模式-六大原则

1、单一职责原则

单一职责原则(Single Responsibility Principle, SPR)。
就一个类而言,应该仅有一个引起它变化的原因。如果一个类承担的职责过多,就等于把这些职责耦合在一起,一个职责的变化可能会削弱或者抑制这个类完成其他职责的能力。这种耦合会导致脆弱的设计,当发生变化时,设计会遭受到意想不到的破坏。

单一职责原则的优点

单一职责原则的核心就是控制类的大小、将对象解耦、提高其内聚性。

  • 降低类的复杂度。一个类只负责一项职责,其逻辑肯定要比负责多项职责简单的多。
  • 提高类的可读性。
  • 提高系统的可维护性。
  • 变更影响的风险降低。变更是必然的,如果单一原则遵守得好,当修改一个功能时,可以显著降低对其他功能的影响。

2、开闭原则

开闭原则(Open Closed Principle,OCP)。它是最基础的设计原则,指导我们如何建立一个稳定的、灵活的系统。对于类、模块、函数等应该是可以拓展的,但是不可修改。

对于开发来说,需求肯定是要变化的,但是有新需求,我们就要把类重新改一遍,这显然是令人头疼的。所以我们设计程序时,面对需求的改变要尽可能地保证相对稳定,尽量通过扩展的方式来实现变化,而不是通过修改原有的代码来实现。即能扩展不修改。

使用开闭原则

可以通过 “抽象约束、封装变化” 来实现开闭原则,即通过接口或者抽象类为软件实体定义一个相对稳定的抽象层,而将相同的可变因素封装在相同的具体实现类中。

因为抽象灵活性好,适应性广,只要抽象的合理,可以基本保持软件架构的稳定。而软件中易变的细节可以从抽象派生来的实现类来进行扩展,当软件需要发生变化时,只需要根据需求重新派生一个实现类来扩展就可以了。

3、里氏替换原则

里氏替换原则(Liskov Substiution Principle,LSP)。
所有引用基类(父类)的地方必须能透明地使用其子类的对象。
通俗的来讲就是:子类可以扩展父类的功能,但不能改变父类原有的功能。

里氏替换原则的核心原理是抽象,抽象又依赖于继承。

继承的优缺点

  • 优点
    • 代码重用,减少创建类的成本,每各子类都拥有父类的方法和属性;
    • 子类与父类基本相似,但又与父类有所区别;
    • 提高代码的可扩展性。
  • 缺点
    • 继承是侵入性的,只要继承就必须拥有父类的所有属性和方法;
    • 可能造成子类代码冗余、灵活性降低。
    • 增强了耦合性,当父类的属性、方法修改时,就需要考虑子类的修改。

4、依赖倒置原则

依赖倒置原则(Dependence Inversion Principle, DIP)。
高层模块不应该依赖低层模块,两者都应该依赖于抽象。抽象不应该依赖于细 节,细节应该依赖于抽象。 其核心思想是:要面向接口编程,不要面向实现编程。

Java中,抽象指接口或者抽象类,两者都不能直接被实例化;细节就是实现类,实现接口或者继承抽象类而产生的就是细节。高层模块就是调用端,底层模块就是具体实现类。
依赖倒置原则在java中的表现就是,模块间的依赖通过抽象发生,实现类之间不发生直接的依赖关系,其依赖关系是通过接口或抽象类产生的。

依赖倒置原则的实现方法

依赖倒置原则的目的是 通过要面向接口的编程来降低类间的耦合性,所以我们在实际编程中只要遵循以下4点,就能在项目中满足这个规则。

  • 每个类尽量都有接口或者抽象类,或者抽象类和接口两者都具备
  • 变量的声明类型尽量是接口或是抽象类
  • 任何类都不应从具体类派生
  • 结合里氏替换原则使用

5、接口隔离原则

接口隔离原则(Interface Segregation Principle,ISP)。

一种定义是客户端不应该依赖它不需要的接口;另一种定义是一个类对另一个类的依赖应该建立在最小的接口上。

建立单一接口,不要建立庞大臃肿的接口;尽量细化接口,接口中的方法尽量少。也就是说,我们要 为各个类建立专用的接口,而不要试图建立一个很庞大的接口供所有依赖它的类调用。采用接口隔离原则 对接口进行约束时,要注意以下几点:

  • 接口尽量小,但是有限度。对接口进行细化可以提高程序的灵活设计;但是过小,则会造成接口数量过多,是设计复杂化,所有一定要适度。
  • 为依赖接口的类定制服务,只暴露给调用他需要的方法,它不需要的方法则隐藏起来。只有专注地为一个模块提供定制服务,才能建立最小的依赖关系。
  • 提高内聚,减少对外交互。接口方法尽量少用public修饰。接口是对外的承诺,承诺越少对系统的开发越有利,变更风险也会越少。

6、迪米特原则

迪米特原则(Law of Demeter,LOD)。
一个软件实体应当尽可能少地与其他实体发生相互作用(这也被称为最少知识原则)。

如果一个系统符合迪米特原则,那么当某一个模块发生修改时,就会尽量少的影响其他模块。在设计的时候应当尽量减少对象之间的交互。在设计的时候需要注意一下几点:

  • 在类的划分上,应当尽量创建松耦合的类。类之间的耦合度越低,就越有利复用。
  • 在类的结构设计上,每一个类都应当尽量降低其成员变量和成员函数的访问权限。
  • 在对其他类的引用上,一个对象对其他对象的引用应当降到最低。

迪米特法则的做法观念就是类间解耦,弱耦合,只有弱耦合了以后,类的复用率才可以提高,其要求的结果就是产生了大量的中转或跳转类,导致的复杂性提高,同时也为维护带来了难度,所以在采用迪米特法则时需要反复权衡,既做到让结构清晰,又做到高内聚低耦合。

总结

单一职责原则告诉我们实现类要职责单一;

开闭原则是总纲,他告诉我们要对扩展开放,对修改关闭。

里氏替换原则告诉我们不要破坏继承体系;

依赖倒置原则告诉我们要面向接口编程;

接口隔离原则告诉我们在设计接口的时候要精简单一;

迪米特法则告诉我们要降低耦合;

在开发项目中,不仅要完成项目的开发,还要考虑后续的升级、维护。这就需要我们在满足需求且不破坏系统稳定性的前提下保持可扩展性、高内聚低耦合,在经历版本迭代后依然保持清晰、灵活、稳定的系统架构。那么就需要我们尽可能的去遵循面向对象的六大原则。

尽可能遵循这些规范会让你的设计无限接近完美,但世界上本就没有十全十美的东西,凡事都要有个度,不要认死理,不要为了"套模式"而应用设计模式,要具体问题具体分析,根据实际情况进行权衡。

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

推荐阅读更多精彩内容