美文网首页
设计模式基本原则及其作用

设计模式基本原则及其作用

作者: yongphone | 来源:发表于2018-07-30 15:40 被阅读0次

    单一职责原则

    每个类和接口都应该是功能职责单一的,在实际应用上,我们应该保证接口职责单一,类尽量做到职责单一

    好处:

    - 类的复杂性降低,实现什么职责都有清晰明确的定义

    - 复杂性降低—>可读性提高—>可维护性提高

    - 变更引起的风险降低,如果接口的单一职责做得好,那么接口的修改只会对相应的实现类造成影响,对其他接口没有影响,对系统的扩展性、可维护性都有帮助

    里氏替换原则

    所有父类出现的地方,子类都可以出现,并且运行结果(或者说被调用的方法)与父类出现时候保一致

    好处:

    增强程序的健壮性,版本升级的时候可以保持非常好的兼容性,即使增加子类,原有的子类还可以继续运行。LSP是继承复用的基石,只有当衍生类可以替换掉基类,软件单位的功能不受到影响时,基类才能真正被复用,而衍生类也能够在基类的基础上增加新的行为。

    保证兼容性手段:(契约性设计)

    尽量不用重写父类方法,子类重载时参数可放大不可缩小。

    依赖倒置原则

    高层模块之间应该互相依赖其抽象,抽象不应该依赖细节,细节应该依赖抽象

    好处:

    - 松耦合:通过抽象使各个类或模块的实现彼此独立,实现类或模块间的松耦合,同时屏蔽细节对抽象的影响

    - 提高系统的稳定性:被依赖者不应该让依赖者承担其扩展时候带来的影响,因为使用依赖倒置,通过接口可以避免扩展实现带来的影响

    - 降低并行开发引起的风险:不使用依赖倒置的环境中,所有开发都是单线程的

    接口隔离原则

    客户端不应该依赖它不需要的接口(类间的依赖关系应该建立在最小的接口上)

    好处:

    通过分散定义多个接口,可以预防未来变更的扩散,提高系统的灵活性和可维护性。

    单一职责与接口隔离对比:两者审视的角度不同

    单一职责注重业务逻辑的划分;接口隔离注重接口的方法应该尽量少,只暴露别人需要的部分

    根据接口隔离原则划分接口的时候,首先必须满足单一职责原则

    迪米特法则

    一个对象应该对其他对象有最少了解(只与朋友类交流、两部分之间的交流做适当的控制)

    好处:

    弱耦合

    (弱耦合可以使得类的复用率提高,但是会产生大量的中转类,导致系统复杂性的提高)

    开闭原则

    一个软件实体应该对扩展开放,对修改关闭

    前面五个原则是对开闭原则的具体解析,开闭原则是一个比较虚的原则。

    好处:

    在对扩展开放的同时,尽量减少对原有代码的修改,保持历史代码的纯洁性,提高系统的稳定性

    相关文章

      网友评论

          本文标题:设计模式基本原则及其作用

          本文链接:https://www.haomeiwen.com/subject/dyzxvftx.html