设计模式六大原则 节选自《闻缺陷则喜》(此书可免费下载)

      1. 设计模式六大原则

单一职责原则 Single Responsibility Principle,开闭原则 Open-Closed Principle 里氏代换原则 Liskov Substitution Principle迪米特法Law of Demeter接口隔离原则Interface Segregation Principle 依赖倒置原则Dependence Inversion Principle,可以记为SOLID

 

        1. 单一职责原则

定义:不要存在多于一个导致类变更的原因。问题由来:类C有两个成员函数F1、F2负责职责P1、P2,由于P1发生变化对F1进行了修改,对F1修改可能使原本正常运行的F2发生故障。职责扩散,职责P被分为职责P1和P2。解决方法:两个类C1、C2分别对应P1、P2。DAO(数据存储对象)模式,一个类的对应一个数据库的表,四个函数分别对应增删查改。之所以不是4个类分别对应增删查改,是因为最可能的修改的原因是:表结构发生变化。这种情况下增删查改都需要修改。

        1. 开闭原则

一个软件实体应当对扩展开放,对修改关闭。通俗的说:可以增加接口和修改的接口的实现;不能删除、修改接口。  常见方法:

 抽象约束抽象。a,通过接口或抽象类约束扩展;b,参数类型、引用对象尽量使用接口或者抽象类;c,抽象层尽量保持稳定。

 元数据,通俗地说就是配置参数,参数可以从文件中获得,也可以从数据库中获得。

 制定项目章,章程优于配置。

 封装变化,比如将某种可能的变化封装成类。

        1. 克服继承的缺点——里式替换原则

矩形类有两个成员函数:设置长和宽;正方形派生于矩形,重写了这两个函数,以确保长宽相等。某函数形参是矩形,实参是正方形,长宽分别设置成4和2,结果是:长宽都是2。

  • 里式替换原则指将一个基类对象替换成它的子类对象,程序将不会产生任何错误。
  • 子类只能重写父类的抽象方法,不能覆盖父类的非抽象方法,可增加自己的方法。
  • 当子类的方法重载父类的方法时,方法的前置条件(即方法的输入/入参)要比父类方法的输入参数更加宽松。方法的后置条件(即方法的输出/返回值)相反。
        1. 迪米特法则

迪米特法则的定义是:只与你的直接朋友交谈。直接朋友:成员变量、方法的输入输出参数、返回值中的类。非直接朋友:局部变量、直接朋友的成员变量。常用原则:

  • 优先考虑将一个类设置成不变类。
  • 尽量降低一个类的访问权限。   
  • 谨慎使用Serializable   
  • 尽量降低成员的访问权限。
        1. 接口隔离原则

定义:客户端不应该依赖它不需要的接口;一个类对另一个类的依赖应该建立在最小的接口上。反例:不同的用户使用一个大接口。注意:

  • 接口尽量小,但是要有限度。接口小提升灵活性,接口多增加复杂性。
  • 只暴露给调用的类它需要的方法,它不需要的方法则隐藏起来。
  • 接口用最少的方法去完成最多的事情
        1. 面向接口编程—依赖倒置原则
  • 高层模块不应该依赖低层模块,两者都应该依赖其抽象
  • 抽象不应该依赖细节
  • 细节应该依赖抽象
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

闻缺陷则喜何志丹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值