让代码更灵活,让软件更健壮,让开发更快乐...编程
此意何解设计
就一个类而言,应该仅有一个引发它变化的缘由。对象
知识点接口
- 若是一个类承担的职责过多,就等于把这些指责偶合在一块儿,一个职责的变化可能会削弱或者抑制这个类完成其余职责的能力。这种耦合会致使脆弱的设计,当变化发生时,设计会遭受到意想不到的破坏。
- 软件设计真正要作的许多内容,就是发现职责并把那些职责相互分离。
此意何解开发
若是两个类没必要彼此直接通讯,那么这两个类就不该当发生直接的相互做用。若是其中一个类须要调用另外一个类的某一个方法的话,能够经过第三者转发这个调用。基础
知识点扩展
- 最少知识原则。
- 在类的结构设计上,每个类都应当尽可能下降成员的访问权限。
- 迪米特法则的根本思想是,强调类之间的松耦合。类之间的耦合越弱,越有利于复用,一个处在弱耦合的类被修改,不会对有关系的类形成波及。
此意何解软件
对于扩展是开放的,对于修改是封闭的。权限
知识点程序
- 开发-封闭原则是面向对象设计的核心。可维护、可复用、可扩展、灵活性好
- 面对需求,对程序的改动是经过增长新代码进行的,而不是更改现有的代码。
- 开发人员应该仅对程序中呈现出频繁变化的那些部分作出抽象,然而,对于应用程序中的每个部分都刻意的进行抽象一样不是一个好主意。拒接不成熟的抽象和抽象自己同样重要!
此意何解
- 高层模块不该该依赖低层模块。两个都应该依赖抽象。
- 抽象不该该依赖细节。细节应该依赖抽象。
知识点
- 依赖倒转是面向对象设计的标志
- 针对接口编程,不要对现实编程。
- 抽象应该依赖细节,细节不该该依赖于抽象。
- 程序中全部的依赖关系都是终止于抽象类或者接口,那就是面向对象的设计,反之就是过程化设计。
此意何解
子类型必须可以替换掉它们的父类型。(一个软件实体若是使用的是一个父类的话,那么必定适用于其子类,而其它察觉不出父对象和子对象的区别。也就是说,在软件里面,把父类都替换成它的子类,程序的行为没有变化)
知识点
- 只有当子类能够替换掉父类,软件单位的功能不受到影响时,父类才能真正的被复用,而子类也可以在父类的基础上增长新的行为。
- 因为子类型的可替换性才能使得父类型的模块在无需修改的状况下就能够扩展。