Dtpark's blog 磨刀不误砍柴工,读完硕士再打工

设计模式笔记(一)——设计模式概述


“设计模式是在特定环境下人们解决某类重复出现问题的一套成功或有效的解决方案。”

一、设计模式的分类

设计模式目前种类: GoF的23种 + “简单工厂模式” = 24种。

GoF 提出的设计模式分类

种类 作用
创建型(Creational)模式 如何创建对象
结构型(Structural )模式 如何实现类或对象的组合
行为型(Behavioral)模式 类或对象怎样交互以及怎样分配职责

二、学习设计模式的作用

便于理解如下问题:

  1. 如何将代码分散在几个不同的类中?
  2. 为什么要有“接口”?
  3. 何谓针对抽象编程?
  4. 何时不应该使用继承?
  5. 如果不修改源代码增加新功能?
  6. 更好地阅读和理解现有类库与其他系统中的源代码。

三、如何学好设计模式

设计模式的基础是:多态。

面向人群 学习方法
初学者 积累案例,不要盲目的背类图
初级开发人员 多思考,多梳理,归纳总结,尊重事物的认知规律,注意临界点的突破,不要浮躁
中级开发人员 合适的开发环境,寻找合适的设计模式来解决问题

四、设计模式总览

名称加粗的模式为后续笔记会介绍的内容

4.1 创建型模式Creational Pattern(6)

模式名称 频率 作用
单例模式 ★★★★☆ 是保证一个类仅有一个实例,并提供一个访问它的全局访问点
简单工厂模式 ★★★☆☆ 通过专门定义一个类来负责创建其他类的实例,被创建的实例通常都具有共同的父类
工厂方法模式 ★★★★★ 定义一个创建产品对象的工厂接口,将实际创建工作推迟到子类中
抽象工厂模式 ★★★★★ 提供一个创建一系列相关或者相互依赖的接口,而无需指定它们具体的类
原型模式 ★★★☆☆ 用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象
建造者模式 ★★☆☆☆ 将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同的表示

4.2 结构型(Structural )模式(7)

模式名称 频率 作用
适配器模式 ★★★★☆ 将一个类的接口转换成客户希望的另外一个接口。使得原本由于接口不兼容而不能一起工作的那些类可以一起工作
桥接模式 ★★★☆☆ 将抽象部分与实际部分分离,使它们都可以独立的变化
组合模式 ★★☆☆☆ 将对象组合成树形结构以表示“部分–整体”的层次结构。使得用户对单个对象和组合对象的使用具有一致性
装饰模式 ★★★☆☆ 动态的给一个对象添加一些额外的职责。就增加功能来说,此模式比生成子类更为灵活
外观模式 ★★★★★ 为子系统中的一组接口提供一个一致的界面,此模式定义了一个高层接口,这个接口使得这一子系统更加容易使用
享元模式 ★☆☆☆☆ 以共享的方式高效的支持大量的细粒度的对象
代理模式 ★★★★☆ 为其他对象提供一种代理以控制对这个对象的访问

4.3 行为型(Behavioral)模式(11)

模式名称 频率 作用
职责链模式 ★★☆☆☆ 在该模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链。请求在这个链上传递,直到链上的某一个对象决定处理此请求,这使得系统可以在不影响客户端的情况下动态地重新组织链和分配责任
命令模式 ★★★★☆ 将一个请求封装为一个对象,从而使你可用不同的请求对客户端进行参数化;对请求排队或记录请求日志,以及支持可撤销的操作
解释器模式 ★☆☆☆☆ 如何为简单的语言定义一个语法,如何在该语言中表示一个句子,以及如何解释这些句子
迭代器模式 ★☆☆☆☆ 提供了一种方法顺序来访问一个聚合对象中的各个元素,而又不需要暴露该对象的内部表示
中介者模式 ★★☆☆☆ 定义一个中介对象来封装系列对象之间的交互。终结者使各个对象不需要显示的相互调用 ,从而使其耦合性松散,而且可以独立的改变他们之间的交互
备忘录模式 ★★☆☆☆ 是在不破坏封装的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态
观察者模式 ★★★★★ 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新
状态模式 ★★☆☆☆ 对象的行为,依赖于它所处的状态
策略模式 ★★★★☆ 准备一组算法,并将每一个算法封装起来,使得它们可以互换
模板方法模式 ★★★☆☆ 得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤
访问者模式 ★☆☆☆☆ 表示一个作用于某对象结构中的各元素的操作,它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作

参考资料

  • https://www.yuque.com/aceld/lfhu8y/pebesh

Similar Posts

Comments