文档章节

设计模式之设计原则

白志华
 白志华
发布于 2015/10/18 10:56
字数 1260
阅读 1
收藏 0

        设计模式(Design Pattern)是面向对象技术的最新进展之一,由于面向对象设计的灵活性,增加了其设计的复杂性,设计模式的出现就是为了提高复用的设计方案,让代码更容易被他人理解、保证代码可靠性。设计模式于己于他人于系统都是多赢的,设计模式使代码编制真正工程化,设计模式是软件工程的基石,如同大厦的一块块砖石一样。

       要想用好设计模式,必须先明白设计模式的六大原则:单一职责原则、开放封闭原则、依赖倒转原则、里氏代换原则、合成聚合复用原则、迪米特法则。

 ①   【单一职责原则SRP】

        单一职责原则,就一个类而言,应该仅有一个引起它变化的原因。如果一个类承担的职责过多,就等于把这些职责耦合在一起,一个职责的变化可能会消弱或者一直这个类完成其他职责的能力。这种耦合会导致脆弱的设计,当变化发生时,设计会遭受到意想不到的破坏。而软件设计真正要做的许多内容,就是发现职责,并把这些职责相互分离。

 ②   【开放封闭原则OCP】

开放-封闭原则,是说软件实体(类、模块、函数等等)应该可以扩展,但是不可以修改。即对于扩展是开放的,对于更改是封闭的。当用户需求的变化,不鞥轻易更改源代码,而是应该创建抽象类,去隔离以后发生的同类变化。这样会使得变化中的系统有一定的稳定性和延续性。

例如当年玉皇大帝在不更改现有天庭秩序的情况下,成功扩展“弼马温”这个秩序(类)。

 ③   【依赖倒转原则DIP】

        抽象不应该依赖细节,细节应该依赖于抽象。即我们要针对接口(抽象类)编程,不要针对与实现编程。

         比如你开车进小区,小王是门卫,每次你到门口,喊一声“小王,帮忙开下门”他就给你开了,但是对于刚搬进小区的小李,他可不认识小王,他怎么通知小王开门呢?假如突然有一天,门卫换了,难道你就不进小区了?答案大家都知道,只要喊“门卫,帮忙开下门”,你和小李就都可以进去了。所以不管门卫和小区的业主怎么换,只要“门卫”这个“接口”是不变,那么业主就可以让门卫给开门。

 ④   【里氏代换原则LSP】

        里氏代换原则,子类型必须能够替换掉他们的父类型。在软件里面,把父类都替换成其子类,程序的行为不会发生变化。

简单来说,子类=父类 [+新功能]。父类的非私有成员都会被子类继承,还可以根据自身情况对继承来的方法DIY。当用子类去实例化父类,调用父类的方法,具体实现则是刚才的子类的方法。(也就是说如果这个父类有多个子类的话,只要用不同的子类去实例化这个父类,那么这个父类对象执行相同的方法,则会执行各自子类对应的同名方法,所以结果也会不同。而这就是“多态”!所以可以说多态是里氏代换原则的体现。)当然反过来是不成立的。例如矩形和正方形,我们可以说正方形是一种特殊的矩形,但不可以说矩形是一种特殊的正方形。

 ⑤   【合成聚合复用原则CARP】

        合成聚合复用原则:尽量使用合成\聚合,尽量不使用类继承。合成聚合是”has  a”的关系,而继承是“is  a”的关系。由于继承是一中强耦合的结构,父类变,子类必变。所以不是“is  a”关系,我们一般不要用继承。优先使用合成聚合复用原则,可以保持每个类的封装,降低继承的层次。

       根据此原则转变后为:

 ⑥   【迪米特法则】

        如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用。如果其中一个类需要调用另一个类的某一个方法时,可以通过第三者转发这个调用。类之间的耦合越弱,就越有利于复用,一个处在弱耦合的类被修改,不会对有关系的类造成波及。也就是说,一个对象对其他对象尽可能少的了解(不要和陌生人说话)。

版权声明:本文为博主原创文章,未经博主允许不得转载。

本文转载自:http://blog.csdn.net/xiaoxian8023/article/details/6932956

白志华
粉丝 34
博文 265
码字总数 57524
作品 0
长沙
程序员
私信 提问
设计模式 2014-12-19

book: 阎宏《JAVA与模式》 架构设计栏目 http://blog.csdn.net/enterprise/column.html 概要: http://bbs.csdn.net/forums/Embeddeddriver 23种设计模式分别是: 1.单例模式 2.工厂方法模式...

jayronwang
2014/12/19
293
0
PHP设计模式(一):简介及创建型模式

我们分三篇文章来总结一下设计模式在PHP中的应用,这是第一篇创建型模式。 一、设计模式简介 首先我们来认识一下什么是设计模式: 设计模式是一套被反复使用、容易被他人理解的、可靠的代码设...

juhenj
2014/05/15
285
2
迈向大牛的重要一步——掌握设计模式

IT职场的小菜经常有这样的疑问: 为什么一个相似的功能,大牛一会儿就搞定,然后悠闲地品着下午茶逛淘宝;而自己加班加点搞到天亮还做不完。 为什么用户提出需求变更后,大牛只需潇洒地敲敲键...

一枚Sir
2015/04/10
331
0
Java设计模式系列一(前言)

说起设计模式,很多人都会觉得这个概念很熟悉,会想到单例模式、工厂模式等等,但是似乎又说不出来什么,说不上它的核心思想和设计原则。其实我们的项目中,为了代码复用,增加可维护性,很多...

Mooree
04/07
26
0
Java 23种设计模式 初步了解

总体来说设计模式分为三大类: 创建型模式,共五种:工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式。 结构型模式,共七种:适配器模式、装饰器模式、代理模式、外观模式、桥接...

engeue
01/02
71
0

没有更多内容

加载失败,请刷新页面

加载更多

总结

一、设计模式 简单工厂:一个简单而且比较杂的工厂,可以创建任何对象给你 复杂工厂:先创建一种基础类型的工厂接口,然后各自集成实现这个接口,但是每个工厂都是这个基础类的扩展分类,spr...

BobwithB
25分钟前
2
0
java内存模型

前言 Java作为一种面向对象的,跨平台语言,其对象、内存等一直是比较难的知识点。而且很多概念的名称看起来又那么相似,很多人会傻傻分不清楚。比如本文我们要讨论的JVM内存结构、Java内存模...

ls_cherish
29分钟前
2
0
友元函数强制转换

友元函数强制转换 p522

天王盖地虎626
昨天
5
0
js中实现页面跳转(返回前一页、后一页)

本文转载于:专业的前端网站➸js中实现页面跳转(返回前一页、后一页) 一:JS 重载页面,本地刷新,返回上一页 复制代码代码如下: <a href="javascript:history.go(-1)">返回上一页</a> <a h...

前端老手
昨天
5
0
JAVA 利用时间戳来判断TOKEN是否过期

import java.time.Instant;import java.time.LocalDateTime;import java.time.ZoneId;import java.time.ZoneOffset;import java.time.format.DateTimeFormatter;/** * @descri......

huangkejie
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部