设计模式的六大原则

开闭原则

定义:一个软件实体如类、模块和函数应该对扩展开放,对修改关闭。

当软件需要变化时,尽量通过扩展软件实体的行为来实现变化,而不是通过修改已有的代码来实现变化。

单一职责原则

定义:不要存在多于一个导致类变更的原因。一个类只负责一项职责

比如,原有一个Animal类有eat()和drink()方法来代表动物的吃喝动作:

public class Animal {

    private void eat() {
        System.out.println("吃");
    }
    
    private void run() {
        System.out.println("跑");
    }
}

但是随着功能需求增加,发生了职责扩散,可能需要管理动物具体的吃什么,喝什么。

一种办法是修改原有的方法来实现,为两个方法都传入一个参数代表具体动物,在方法体中通过参数识别动物来产生对应的具体行为:

public class Animal {

    private void eat(String animal) {
        if (animal == "牛") {
            System.out.println("牛吃草");
        }
        if (animal == "鸡")
        System.out.println("鸡啄米");
    }
    
    private void run() {
        if (animal=="牛" || animal =="狗") {
            System.out.println("四条腿在跑");
        }
        if (animal=="鸡") {
            System.out.println("两条腿在跑");
        }
    }
}

这种解决方法的问题在于每次职责扩散,都需要修改原先的方法,当这个类方法很多时,每次职责扩散意味着你都要修改这个类中的每一个方法。这样很容易由于修改原有代码,会对之前提供给调用者的功能造成影响,对原有程序正确运行有很大的风险(特别是当逻辑变得很复杂的时候,修改代码很容易出bug)。

软件实体(如类、模块和函数)应该是对扩展开放,对修改关闭(开闭原则)。模块要提供新的功能应当尽量在不修改原来代码的情况下进行扩展。例如为不同的动物定义一个继承自Animal的类,在新的类上实现动物特有的动作。

里氏替换原则

定义1:如果对每一个类型为 T1的对象 o1,都有类型为 T2 的对象o2,使得以 T1定义的所有程序 P 在所有的对象 o1 都代换成 o2 时,程序 P 的行为没有发生变化,那么类型 T2 是类型 T1 的子类型。

定义2:所有引用基类的地方能透明地使用其子类的对象

类B继承类A时,除添加新的方法完成新增功能P2外,尽量不要重写父类A的方法,也尽量不要重载父类A的方法(子类可以扩展父类的功能,但不能改变父类原有的功能)。当重载父类的方法时,重载的方法的功能不能与父类对应方法的功能相悖。

继承作为面向对象三大特性之一,在给程序设计带来便利的同时,也带来了弊端。比如使用继承会给程序带来侵入性,程序的可移植性降低,增加了对象间的耦合性,如果被其他的类所继承需要修改时,必须考虑到所有的子类,并且父类修改后,所有涉及到子类的功能都有可能会产生故障。

依赖倒置原则

定义:高层模块不应该依赖低层模块,二者都应该依赖其抽象;抽象不应该依赖细节;细节应该依赖抽象。

依赖倒置原则的核心思想是面向接口编程,程序应当依赖于抽象接口,而不依赖于具体实现,使程序不需要设计任何具体的操作实现,降低了程序与被调用模块间的耦合度。这样搭建起来的程序架构也会相对稳定(例如SpringMVC架构,在Controller那层常常依赖的是Service层的接口,而不是具体实现)。

传递依赖关系有三种方式:接口传递、构造方法传递和setter方法传递。

接口隔离原则

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

即尽量细化接口,为各个类建立其专用的接口,不要试图建立一个庞大的接口去供所有依赖于它的类去调用。因为如果接口庞大,调用这个接口意味着,对应的实现这个接口的实现类必须实现这个接口的所有方法,即使调用这个接口的客户端用不到这么多方法。

但也不能把接口细化的太小,接口设计的太小,接口数量过多会使设计变得复杂。

遵循接口隔离原则不让接口变得臃肿可以提升系统的灵活性与可维护性。

迪米特法则

定义:一个对象应该对其他对象保持最少的了解。

即尽可能少的与其他对象发生相互作用(此相互作用非交互,不是指尽可能少的发生交互,而是对其依赖的对象的了解尽可能少)。

被依赖的类逻辑尽可能的封装在类的内部。除了对外提供public方法,不对外泄露任何信息。这样可以降低类与类之间的耦合性。耦合性越低,代码的复用率才越高。

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

推荐阅读更多精彩内容