设计原则

单一职责原则


就一个类而言应该只有一个引起她变化的原因。

如果一个类承担的职责过多,就等于把这些职责耦合在一起,一个职责的变化可能会削弱或者抑制这个类完成其他职责的能力。这种耦合会导致脆弱的设计,当变化发生时,会有意想不到的破坏。

开放封闭原则


实体(类、模板、函数等等)应该可以扩展,但是不可以修改。

无论设计是多么的“封闭”,都会存在一些无法对之封闭的变化。既然不可能完全的封闭,设计人员必须对于他的设计应该会存在哪些变化封闭做出选择,必须先猜测出最有可能发生变化的种类,然后构造抽象来隔离哪些变化。

依赖倒转原则


A 高层模块不应该依赖底层模块,两个都应该抽象

B 抽象不应该依赖细节。细节应该依赖抽象

简单的说就是面向接口编程

里氏代换原则


子类型必须能够替换掉她的父类型

一个软件实体如果使用的是一个父类的话,那么一定适用于其子类,而且他察觉不出父类对象和子类对象的区别。也就是说,在软件里面把父类都替换成了子类,程序的行为没有发生改变

 迪米特法则


如果两个类不必彼此直接通信,那么这两个类就不应该发生直接的相互作用。如果其中一个类要调用另外一个类的某一个方法,可以通过第三者转发这个调用。

合成/聚合复用原则


尽量使用合成/聚合,不使用类继承

聚合体现的是一种弱 拥有 的关系,体现的是A对象可以包含B对象,但是B对象不是A对象的一部分

合成则是一种强的 拥有 的关系,体现了严格的部分和整体的关系,部分和整体的生命周期一样

原文地址:https://www.cnblogs.com/heml/p/4620430.html