当前位置: 首页 > news >正文

依赖倒置原则(DIP)

当然可以!这次我们来详细讲解 依赖倒置原则(DIP: Dependency Inversion Principle),它是 SOLID 五大设计原则中的压轴,也是最关键的“架构型原则”。

我将从:

  1. 什么是依赖倒置原则(定义)
  2. 为什么需要(价值)
  3. 优劣对比
  4. Python 例子(先错再对)
  5. Mermaid 图(清晰结构)

带你完整理解它。


🧠 一句话定义

高层模块不应该依赖低层模块,二者都应该依赖于抽象。抽象不应该依赖于细节,细节应该依赖于抽象。

简化版本:

程序要依赖接口,而不是依赖实现。


🎯 为什么需要依赖倒置原则?

你有没有遇到过:

  • 改了一个类,连锁影响到很多地方?
  • 想替换一个模块,但发现到处都“绑死”了原来的类?

这就是因为:

高层模块直接依赖低层细节 → 系统结构僵硬,耦合严重!


✅ 优点 vs ❌ 缺点

优点(为什么需要)缺点
✅ 解耦上下层模块初学者理解难
✅ 方便测试、Mock多了抽象接口
✅ 易扩展和替换程序启动需明确注入依赖
✅ 结构更清晰设计成本略升

🐍 Python 示例

❌ 错误示范:高层模块依赖底层类

class MySQLDatabase:def connect(self):print("Connected to MySQL")class UserService:def __init__(self):self.db = MySQLDatabase()  # ❌ 直接依赖具体类def get_user(self):self.db.connect()print("Getting user from database")

问题:

  • UserService 绑死了 MySQLDatabase
  • 不能轻松换成 MongoDB、Mock 测试版本。

✅ 正确示范:依赖倒置 + 依赖注入

from abc import ABC, abstractmethod# --------------------
# 抽象接口
# --------------------
class Database(ABC):@abstractmethoddef connect(self):pass# --------------------
# 具体实现类
# --------------------
class MySQLDatabase(Database):def connect(self):print("Connected to MySQL")class MongoDatabase(Database):def connect(self):print("Connected to MongoDB")# --------------------
# 高层模块(业务逻辑)
# --------------------
class UserService:def __init__(self, db: Database):  # 依赖抽象,不依赖具体实现self.db = dbdef get_user(self):self.db.connect()print("Getting user from the database")# --------------------
# 主程序入口(运行时注入依赖)
# --------------------
if __name__ == "__main__":# 使用 MySQLmysql_db = MySQLDatabase()user_service_mysql = UserService(mysql_db)user_service_mysql.get_user()print()# 使用 MongoDB(只换对象,不改逻辑)mongo_db = MongoDatabase()user_service_mongo = UserService(mongo_db)user_service_mongo.get_user()

✅ 优势:

  • UserService 完全不关心用的是哪种数据库;
  • 测试时可以传入 MockDatabase
  • 扩展 MongoDB/PostgreSQL 不改原来的代码!

🧭 结构图(Mermaid)

depends on
UserService
+get_user()
«interface»
Database
+connect()
MySQLDatabase
+connect()
MongoDatabase
+connect()

🏁 总结一句话

依赖倒置原则让系统依赖“接口而不是实现”,从而实现模块解耦、系统灵活、扩展容易。


📌 实战应用场景

  • 工厂模式
  • Web框架中的 服务注册+依赖注入
  • 测试时用 Mock 替换真实实现
  • 插件化系统:核心代码依赖统一接口,插件各自实现

如果你想,我还能帮你加一个 “依赖注入容器(IoC)”的Python简易实现,进一步升级你的架构能力,要吗?🚀

相关文章:

  • DeepSeek-R1模型蒸馏
  • Demo02_基于寄存器+标准库开发的项目
  • vulkanscenegraph显示倾斜模型(6.2)-记录与提交
  • LLMs Tokenizer Byte-Pair Encoding(BPE)
  • 上位机知识篇---粗细颗粒度
  • 【前端知识】Vue3状态组件Pinia详细介绍
  • MySQL:联合查询
  • 文章四《深度学习核心概念与框架入门》
  • 虚拟环境配置——Windows11 环境在VMware中部署 OpenStack
  • 一、Shell 脚本基础
  • 藏文文本自动分词工具学习实践
  • 免费抠图--在线网站、无需下载安装
  • DeepSeek实战--各版本对比
  • 在网鱼网吧测试文件试验成功
  • Java 入门:自定义标识符规则解析
  • 树状数组 + 线段树
  • 推荐系统(1)--用户协同过滤和物品协同过滤
  • Codeforces Round 1022 (Div. 2) A ~ C
  • 「Mac畅玩AIGC与多模态14」开发篇10 - 固定文本输出工作流示例
  • 广告事件聚合系统设计
  • “矿茅”国际化才刚开始?紫金矿业拟分拆境外黄金矿山资产于港交所上市
  • 消息人士称以色列政府初步同意扩大对加沙军事行动
  • 国台办:“台独”是绝路,外人靠不住
  • 东风着陆场近日气象条件满足神舟十九号安全返回要求
  • 中国人保聘任田耕为副总裁,此前为工行浙江省分行行长
  • 白云山一季度营收净利双降,此前称今年将挖掘盘活自身资源