设计模式原理

原则

里氏代换原则

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

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

依赖倒转原则

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

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

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

接口隔离原则

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

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

合成/聚合复用原则

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

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

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

迪米特法则

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

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

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

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

重点在于对象之间的解耦

相关推荐
苏渡苇34 分钟前
优雅应对异常,从“try-catch堆砌”到“设计驱动”
java·后端·设计模式·学习方法·责任链模式
短剑重铸之日1 小时前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
feasibility.2 小时前
AI 编程助手进阶指南:从 Claude Code 到 OpenCode 的工程化经验总结
人工智能·经验分享·设计模式·自动化·agi·skills·opencode
BD_Marathon2 小时前
七大设计原则介绍
设计模式
YigAin5 小时前
Unity23种设计模式之 享元模式
设计模式·享元模式
范纹杉想快点毕业18 小时前
实战级ZYNQ中断状态机FIFO设计
java·开发语言·驱动开发·设计模式·架构·mfc
茂桑1 天前
DDD领域驱动设计-基础设施层
设计模式·架构
小温冲冲1 天前
通俗且全面精讲工厂设计模式
设计模式
进击的小头1 天前
设计模式与C语言高级特性的结合
c语言·设计模式
小温冲冲1 天前
通俗且全面精讲单例设计模式
开发语言·javascript·设计模式