设计模式原理

原则

里氏代换原则

一般来说,对违反里氏代换原则的设计进行重构时,可以采取两个办法:一是加入一个抽象超类;二是将继承关系改写合成 / 聚合关系。

重点在于利用抽象类或者接口来声明变量

依赖倒转原则

只要一个被引用的对象存在抽象类型,就应当在任何引用此对象的地方使用抽象类型,包括参量的类型声明、方法返还类型的声明、属性变量的类型声明等。

以抽象方式耦合是依赖倒转原则的关键。由于一个抽象耦合关系总要涉及具体类从抽象类继承,并且需要保证在任何引用到基类的地方都可以改换成其子类,因此,里氏代换原则是依赖倒转原则的基础。

重点在于提取抽象类或接口+里氏代换原则

接口隔离原则

使用多个专门的接口比使用单一的总接口要好

重点在于对接口进行功能拆分,只提供需要客户端需要的,非必要不暴露

合成/聚合复用原则

合成或聚合可以将已有的对象纳入到新对象中,使之成为新对象的一部分

重点在于区分 "Has-A" 与 "Is-A" ,也就是要去判断是要在A类中存B类对象引用还是A类继承B类

"Is-A" 是严格的分类学意义上的定义,意思是一个类是另一个类的 "一种"。而 "Has-A" 则不同,它表示某一个角色具有某一项责任。导致错误地使用继承而不是合成 / 聚合的一个常见的原因是错误地把 "Has-A" 当做 "Is-A"。"Is-A" 代表一个类是另一个类的一种;"Has-A" 代表一个类是另一个类的一个角色,而不是另一个类的一个特殊种类。

迪米特法则

如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用。如果其中的一个类需要调用另一个类的某一个方法的话,可以通过第三者转发这个调用。

"朋友" 的定义在迪米特法则的语境中,"朋友" 通常指以下对象:

  • 当前对象本身;
  • 以参数形式传入当前对象方法的对象;
  • 当前对象的成员对象;
  • 当前对象成员对象的成员对象(部分场景下)。

狭义的迪米特法则要求一个对象仅仅与其朋友发生相互作用。

重点在于对象之间的解耦

相关推荐
geovindu15 小时前
go: Strategy Pattern
开发语言·设计模式·golang·策略模式
嵌入式学习_force20 小时前
02_state
设计模式·蓝牙
qcx231 天前
Warp源码深度解析(七):Token预算策略——双轨计费、上下文溢出与摘要压缩
人工智能·设计模式·rust·wrap
Cosolar2 天前
提示词工程面试题系列 - Zero-Shot Prompting 和 Few-Shot Prompting 的核心区别是什么?
人工智能·设计模式·架构
geovindu2 天前
go:Template Method Pattern
开发语言·后端·设计模式·golang·模板方法模式
钝挫力PROGRAMER2 天前
贫血模型的改进
java·开发语言·设计模式·架构
qcx232 天前
Warp源码深度解析(二):自研GPU UI框架——WarpUI的ECH模式与渲染管线
人工智能·ui·设计模式·rust
qcx232 天前
Warp源码深度解析(三):Block-Based终端引擎——Grid模型、PTY与Shell Integration
人工智能·设计模式·架构·wrap
mounter6252 天前
Linux Kernel Design Patterns (Part 2):从经典链表到现代 XArray,拆解内核复杂数据结构的设计哲学
linux·数据结构·链表·设计模式·内存管理·kernel
rrr22 天前
【PyQt5】| 多线程设计模式
开发语言·qt·设计模式