Android 设计模式的六大原则

Android 设计模式的六大原则

前言

记录一下Android设计模式的六大原则,大家以后写代码就可以按照这六大原则来构建代码的框架。

1.单一职责原则(Single Responsibility Principle,SRP)

定义:一个类应只包含单一的职责

  • 一个类职责过大的话,首先引起的问题就是这个类比较大,显得过于臃肿,同时其复用性是比较差的
  • 其次就是如果修改某个职责,有可能引起另一个职责发生错误。这是我们极力所避免的,因此设计一个类时我们应当去遵循单一职责原则。

 

2.开放封闭原则(Open - ClosedPrinciple,OCP)

定义:一个模块、类、函数应当是对修改关闭,扩展开放

  • 修改原有的代码可能导致原本正常的功能出现问题。
  • 因此,当需求有变化时,最好是通过扩展来实现,增加新的方法满足需求,而不是去修改原有代码。

 

3.里氏代换原则(Liskov Substitution Principle,LSP)

定义:使用父类的地方能够使用子类来替换,反过来,则不行

  •  使用子类对象去替换父类对象,程序将不会产生错误
  • 因此在程序中尽量使用基类类型来对对象进行定义,而在运行时再确定其子类类型,用子类对象来替换父类对象。
  • 需要注意的事:
  • 子类所有的方法必须在父类中声明,或子类必须实现父类中声明的所有方法。如果一个方法只存在子类中,没有在父类声明,则无法在以父类定义的对象中使用该方法。
  • 父类应当被尽量设计为抽象或者接口,让子类继承父类或实现父接口,并实现现在父类中声明的方法,运行时,子类实例替换父类实例,我们可以很方便地扩展系统的功能,同时无须修改原有子类的代码,增加新的功能可以通过增加一个新的子类来实现。

 

4.依赖倒转原则(Dependence Inversion Principle,DIP)

定义:抽象不应该依赖于细节,细节应当依赖于抽象

  • 即要面向接口编程,而不是面向具体实现去编程。
  • 高层模块不应该依赖低层模块,应该依赖抽象。

 

5.接口隔离法则(Interface Segregation Principle,ISP)

定义:一个类对另一个类的依赖应该建立在最小的接口上

  • 一个类不应该依赖它不需要的接口。
  • 接口的粒度要尽可能小,如果一个接口的方法过多,可以拆成多个接口。

 

6.迪米特法则(Law of Demeter,LoD)

定义:一个类尽量不要与其他类发生关系

  • 一个类对其他类知道的越少,耦合越小
  • 当修改一个类时,其他类的影响就越小,发生的错误的可能性就越小。

 

 

 参考

 

 

 

 

 

 

posted @ 2021-01-18 19:51  东慕雨  阅读(439)  评论(0编辑  收藏  举报