Dawn's Blogs

分享技术 记录成长

0%

Easy搞定Golang设计模式 (1) 面向对象设计原则

设计模式概述

GoF 提出的设计模式总共有 23 种,包括三种类型:

  • 创建型模式:如何创建对象。
  • 结构型模式:如何实现对象的组合。
  • 行为型模式:对象如何交互、怎样分配职责。

23 种设计模式 + 简单工厂模式,就是全部的 24 种设计模式。

设计模式总结

24 种设计模式总结如下:

  • 创建型模式(6种):
    • 单例模式:保证一个类只有一个实例,提供一个访问这个实例的全局访问点
    • 简单工厂模式:通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。
    • 工厂方法模式:定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类中。
    • 抽象工厂模式:提供一个创建一系列相关或者相互依赖的接口,而无需指定它们具体的类。
    • 原型模式:用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。
    • 建造者模式:将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示。
  • 结构型模式(7种):
    • 适配器模式:将一个类的接口转换成客户希望的另外一个接口。使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。
    • 装饰器模式:动态的给一个对象添加一些额外的职责。就增加功能来说,此模式比生成子类更为灵活。
    • 外观模式:为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
    • 代理模式:为其他对象提供一种代理以控制对这个对象的访问
    • 桥接模式:将抽象部分与实际部分分离,使它们都可以独立的变化。
    • 组合模式:将对象组合成树形结构以表示“部分–整体”的层次结构。使得用户对单个对象和组合对象的使用具有一致性。
    • 亨元模式:以共享的方式高效的支持大量的细粒度的对象。
  • 行为型模式(11种):
    • 命令模式:一个请求封装为一个对象,从而使你可用不同的请求对客户端进行参数化;对请求排队或记录请求日志,以及支持可撤销的操作。
    • 观察者模式:定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新。
    • 策略模式:准备一组算法,并将每一个算法封装起来,使得它们可以互换。
    • 模板方法模式:子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤。
    • 解释器模式:如何为简单的语言定义一个语法,如何在该语言中表示一个句子,以及如何解释这些句子。
    • 迭代器模式:提供了一种方法顺序来访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示。
    • 中介者模式:定义一个中介对象来封装系列对象之间的交互。终结者使各个对象不需要显示的相互调用 ,从而使其耦合性松散,而且可以独立的改变他们之间的交互。
    • 备忘录模式:是在不破坏封装的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。
    • 状态模式:对象的行为,依赖于它所处的状态。
    • 访问者模式:表示一个作用于某对象结构中的各元素的操作,它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。

面向对象设计原则

面向对象设计原则旨在提高软件的可维护性和可复用性。面向对象设计原则有以下原则:

名称 定义
单一职责原则(Single Responsibility Principle,SRP) 类的职责单一,对外只提供一种功能,而引起类变化的原因都应该只有一个。
开闭原则(Open-Closed Principle,OCP) 类的改动是通过增加代码进行的,而不是修改源代码。
里氏代换原则(Liskov Substitution Principle,LSP) 任何抽象类(interface接口)出现的地方都可以用他的实现类进行替换,实际就是虚拟机制,语言级别实现面向对象功能。
依赖倒转原则(Dependence Inversion Principle,DIP) 依赖于抽象(接口),不要依赖具体的实现(类),也就是面向接口编程
接口隔离原则(Interface Segregation Principle,ISP) (不重要)不应该强迫用户的程序依赖他们不需要的接口方法。一个接口应该只提供一种对外功能,不应该把所有操作都封装到一个接口中去。
合成复用原则(Composite Reuse Principle,CRP) 如果使用继承,会导致父类的任何变换都可能影响到子类的行为。如果使用对象组合,就降低了这种依赖关系。对于继承和组合,优先使用组合
迪米特法则(Law of Demeter, LoD) 一个对象应当对其他对象尽可能少的了解,从而降低各个对象之间的耦合,提高系统的可维护性。例如在一个程序中,各个模块之间相互调用时,通常会提供一个统一的接口来实现。这样其他模块不需要了解另外一个模块的内部实现细节,这样当一个模块内部的实现发生改变时,不会影响其他模块的使用。(黑盒原理)