设计模式(8)——SOLID原则之依赖倒置原则

设计模式(7)------SOLID原则之依赖倒置原则

概念

高层次的类不应该依赖于低层次的类。两者都应该依赖于抽象接口。抽象接口不应依赖于具体实现。具体实现应该依赖于抽象接口。

  • 底层次类:实现基础操作的类(如磁盘操作、传输网络数据与操作数据库)。
  • 高层次类:包含负责的业务逻辑以指导底层次类执行特定操作。

使用

当开发新系统时,有时人们习惯先设计底层次类,然后再开发高层此类。一部分人直观认为如果低层次的类没有实现或不确定,就无法确定高层次类能实现哪些东西。如果采用了这种设计思路,那高层次类更有可能会依赖低层次类。

依赖倒置原则建议采用以下方式设计:

  1. 使用业务术语来对高层次类依赖的低层次操作接口进行描述。例如打开报表文件,业务应该调用的是openReport(file),而不是openFile()readBytes()CloseFile()等低层次类中的方法。
  2. 基于上述业务术语抽象的接口创建高层次类,而不是基于低层次类
  3. 低层次实现接口,它们将依赖业务逻辑层,从而完成了依赖倒置

示例

在本例中,高层次的预算报告类(BudgetReport)使用低层次的数据库类(MySQLDatabase)来读取和保存其数据。这意味着低层次类中的任何改变(例如当数据库服务器发布新版本时)都可能会影响到高层次的类,但高层次的类不应关注数据存储的细节。

要解决这个问题,你可以创建一个描述读写操作的高层接口,并让报告类使用该接口代替低层次的类。然后你可以修改或扩展低层次的原始类来实现业务逻辑声明的读写接口。

其结果是原始的依赖关系被倒置:现在低层次的类依赖于高层次的抽象。

相关推荐
o0向阳而生0o9 分钟前
105、23种设计模式之策略模式(14/23)
设计模式·策略模式
charlie1145141912 小时前
精读C++设计模式20 —— 结构型设计模式:桥接模式
开发语言·c++·学习·设计模式·桥接模式·c++23·概论
da_vinci_x3 小时前
设计稿秒出“热力图”:AI预测式可用性测试工作流,上线前洞察用户行为
前端·人工智能·ui·设计模式·可用性测试·ux·设计师
大飞pkz8 小时前
【设计模式】访问者模式
开发语言·设计模式·c#·访问者模式
青草地溪水旁10 小时前
设计模式(C++)详解——策略模式(2)
c++·设计模式·策略模式
笨手笨脚の10 小时前
设计模式-装饰器模式
java·设计模式·装饰器模式·结构型设计模式
charlie11451419119 小时前
精读 C++20 设计模式:行为型设计模式 — 访问者模式
c++·学习·设计模式·访问者模式·c++20
我真的是大笨蛋1 天前
依赖倒置原则(DIP)
java·设计模式·性能优化·依赖倒置原则·设计规范
bkspiderx1 天前
C++设计模式之行为型模式:命令模式(Command)
c++·设计模式·命令模式
xindoo1 天前
AI Agent 设计模式:从理论到实践的完整指南
人工智能·设计模式