1.每日设计模式-理论

目录

一、什么是设计模式

二、设计原则

三、设计模式的种类


代码地址:patterns: 每日设计模式

一、什么是设计模式

软件设计模式(Design Pattern)是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结,使用设计模式是为了可重用代码、让代码更容易被他人理解并且保证代码可靠性。

一句大白话可以总结:在一定环境下,用固定套路解决问题。

二、设计原则

对于面向对象软件系统的设计而言,在支持可维护性的同时,提高系统的可复用性是一个至关重要的问题,**如何同时提高一个软件系统的可维护性和可复用性是面向对象设计需要解决的核心问题之一。**在面向对象设计中,可维护性的复用是以设计原则为基础的。每一个原则都蕴含一些面向对象设计的思想,可以从不同的角度提升一个软件结构的设计水平。

**面向对象设计原则为支持可维护性复用而诞生,这些原则蕴含在很多设计模式中,它们是从许多设计方案中总结出的指导性原则。**面向对象设计原则也是我们用于评价一个设计模式的使用效果的重要指标之一。

原则的目的: 高内聚,低耦合

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

三、设计模式的种类

  1. 创建型(Creational)模式:如何创建对象;
  2. 结构型(Structural )模式:如何实现类或对象的组合;
  3. 行为型(Behavioral)模式:类或对象怎样交互以及怎样分配职责。

有一个"简单工厂模式"不属于GoF 23种设计模式,但大部分的设计模式书籍都会对它进行专门的介绍。

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

相关推荐
m0_748233171 天前
30秒掌握C++核心精髓
开发语言·c++
Fleshy数模1 天前
从数据获取到突破限制:Python爬虫进阶实战全攻略
java·开发语言
Duang007_1 天前
【LeetCodeHot100 超详细Agent启发版本】字母异位词分组 (Group Anagrams)
开发语言·javascript·人工智能·python
像少年啦飞驰点、1 天前
零基础入门 Spring Boot:从“Hello World”到可上线的 Web 应用全闭环指南
java·spring boot·web开发·编程入门·后端开发
苍煜1 天前
万字详解Maven打包策略:从基础插件到多模块实战
java·maven
froginwe111 天前
Redis 管道技术
开发语言
有来技术1 天前
Spring Boot 4 + Vue3 企业级多租户 SaaS:从共享 Schema 架构到商业化套餐设计
java·vue.js·spring boot·后端
u0109272711 天前
C++中的RAII技术深入
开发语言·c++·算法
东东5161 天前
xxx医患档案管理系统
java·spring boot·vue·毕业设计·智慧城市
superman超哥1 天前
Serde 性能优化的终极武器
开发语言·rust·编程语言·rust serde·serde性能优化·rust开发工具