SOLID

面向对象程序设计5大原则

  • 单一职责原则(Single Responsibility Principle)
  • 开放封闭原则(Open Close Principle)
  • 里氏替换原则(Liskov Substitution Principle)
  • 接口分离原则(Interface Segregation Principle)
  • 依赖倒置原则(Dependency Inversion Principle)

各原则首字母组成单词SOLID

单一职责原则S

一个类应该只有一个引起其变化的原因

人类进入工业化时代,每个人有各自的分工,不再像农民,不仅需要耕种还需要浇水收割等一系列工作。在工作中,每个人都有各自的分工,程序员、产品、售前、售后等等,这样当一个环节需要修改时,其他环节不需要改变。代码需要修改、产品设计发生变化、售前售后过程改变等等,只需要一类人或者说一个类进行改变,其他人并不关注这种变化。

开放封闭原则O

对于扩展是开放的,对于修改是封闭的。修改需求不可避免,而对代码的修改又是容易出错的。

永远不变的就是变化。无论是客户还是产品,都有极大的可能需要修改需求,为了减少工作量,或者说为了保证质量,不应该对源代码就行修改,而是要在其上进行扩展。

里氏替换原则L

子类可以替换父类并且出现在父类出现的任何地方,子类 is a 父类。

父类应该尽量以接口或抽象类的形式出现

父类的实现应该交给对应的子类来处理,调用者调用的是父类的接口,而实际上是子类的对象在做处理。因此,要求子类能够替换父类出现的所有地方。按照这个要求,扩展父类得到新的子类时,可以不影响调用者的使用。

接口分离原则I

使用多个专门的接口,而不要使用单一的总接口

可能本来一类事物都可以继承自一个单一的总接口,但是当需求改变的时候,可能此类中的新事物不能继承其中某些功能,则需要将接口分为几个专门的接口。比如,汽车都有加油和行驶的功能,而新出现的特斯拉则不再需要加油,因此应该将加油与行驶两个接口进行分离,再为特斯拉增加充电接口。

依赖倒置原则D

高层模块不应该依赖底层模块,两者都应该依赖于抽象。具体应该依赖于抽象,而不应使抽象依赖于具体。

要求对抽象进行编程,而不是对实现进行编程。

司机要开车,司机属于高层模块,而汽车属于底层模块。如果,汽车型号确定了,那么司机的操作需要依赖于汽车型号,而当型号改变时,则需要对高层的司机类进行修改,简直令老司机无法忍受。可以由司机类依赖ICar汽车类的接口,这样就可以变换汽车型号而不影响司机的驾驶;或者司机类依赖IDriver接口,汽车类依赖ICar接口,而由IDriver调用ICar中的操作。

避免了实现类之间的相互依赖,当有新的子类出现时,可以通过添加少量代码来实现。

PS.迪米特法则

有时候有人会说面向对象程序设计有6大法则,迪米特法则说的是类直接应该保持低耦合。尽量减少类直接的通信,从而减少相互之间的耦合度。

你可能感兴趣的:(SOLID)