Android进阶之路Android技术知识Android开发

设计模式-六大原则

2019-08-02  本文已影响1人  MonkeyLqj

1、单一职责原则

单一职责原则(Single Responsibility Principle, SPR)。
就一个类而言,应该仅有一个引起它变化的原因。如果一个类承担的职责过多,就等于把这些职责耦合在一起,一个职责的变化可能会削弱或者抑制这个类完成其他职责的能力。这种耦合会导致脆弱的设计,当发生变化时,设计会遭受到意想不到的破坏。

单一职责原则的优点

单一职责原则的核心就是控制类的大小、将对象解耦、提高其内聚性。

2、开闭原则

开闭原则(Open Closed Principle,OCP)。它是最基础的设计原则,指导我们如何建立一个稳定的、灵活的系统。对于类、模块、函数等应该是可以拓展的,但是不可修改。

对于开发来说,需求肯定是要变化的,但是有新需求,我们就要把类重新改一遍,这显然是令人头疼的。所以我们设计程序时,面对需求的改变要尽可能地保证相对稳定,尽量通过扩展的方式来实现变化,而不是通过修改原有的代码来实现。即能扩展不修改。

使用开闭原则

可以通过 “抽象约束、封装变化” 来实现开闭原则,即通过接口或者抽象类为软件实体定义一个相对稳定的抽象层,而将相同的可变因素封装在相同的具体实现类中。

因为抽象灵活性好,适应性广,只要抽象的合理,可以基本保持软件架构的稳定。而软件中易变的细节可以从抽象派生来的实现类来进行扩展,当软件需要发生变化时,只需要根据需求重新派生一个实现类来扩展就可以了。

3、里氏替换原则

里氏替换原则(Liskov Substiution Principle,LSP)。
所有引用基类(父类)的地方必须能透明地使用其子类的对象。
通俗的来讲就是:子类可以扩展父类的功能,但不能改变父类原有的功能。

里氏替换原则的核心原理是抽象,抽象又依赖于继承。

继承的优缺点

4、依赖倒置原则

依赖倒置原则(Dependence Inversion Principle, DIP)。
高层模块不应该依赖低层模块,两者都应该依赖于抽象。抽象不应该依赖于细 节,细节应该依赖于抽象。 其核心思想是:要面向接口编程,不要面向实现编程。

Java中,抽象指接口或者抽象类,两者都不能直接被实例化;细节就是实现类,实现接口或者继承抽象类而产生的就是细节。高层模块就是调用端,底层模块就是具体实现类。
依赖倒置原则在java中的表现就是,模块间的依赖通过抽象发生,实现类之间不发生直接的依赖关系,其依赖关系是通过接口或抽象类产生的。

依赖倒置原则的实现方法

依赖倒置原则的目的是 通过要面向接口的编程来降低类间的耦合性,所以我们在实际编程中只要遵循以下4点,就能在项目中满足这个规则。

5、接口隔离原则

接口隔离原则(Interface Segregation Principle,ISP)。

一种定义是客户端不应该依赖它不需要的接口;另一种定义是一个类对另一个类的依赖应该建立在最小的接口上。

建立单一接口,不要建立庞大臃肿的接口;尽量细化接口,接口中的方法尽量少。也就是说,我们要 为各个类建立专用的接口,而不要试图建立一个很庞大的接口供所有依赖它的类调用。采用接口隔离原则 对接口进行约束时,要注意以下几点:

6、迪米特原则

迪米特原则(Law of Demeter,LOD)。
一个软件实体应当尽可能少地与其他实体发生相互作用(这也被称为最少知识原则)。

如果一个系统符合迪米特原则,那么当某一个模块发生修改时,就会尽量少的影响其他模块。在设计的时候应当尽量减少对象之间的交互。在设计的时候需要注意一下几点:

迪米特法则的做法观念就是类间解耦,弱耦合,只有弱耦合了以后,类的复用率才可以提高,其要求的结果就是产生了大量的中转或跳转类,导致的复杂性提高,同时也为维护带来了难度,所以在采用迪米特法则时需要反复权衡,既做到让结构清晰,又做到高内聚低耦合。

总结

单一职责原则告诉我们实现类要职责单一;

开闭原则是总纲,他告诉我们要对扩展开放,对修改关闭。

里氏替换原则告诉我们不要破坏继承体系;

依赖倒置原则告诉我们要面向接口编程;

接口隔离原则告诉我们在设计接口的时候要精简单一;

迪米特法则告诉我们要降低耦合;

在开发项目中,不仅要完成项目的开发,还要考虑后续的升级、维护。这就需要我们在满足需求且不破坏系统稳定性的前提下保持可扩展性、高内聚低耦合,在经历版本迭代后依然保持清晰、灵活、稳定的系统架构。那么就需要我们尽可能的去遵循面向对象的六大原则。

尽可能遵循这些规范会让你的设计无限接近完美,但世界上本就没有十全十美的东西,凡事都要有个度,不要认死理,不要为了"套模式"而应用设计模式,要具体问题具体分析,根据实际情况进行权衡。

上一篇 下一篇

猜你喜欢

热点阅读