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

设计模式六大原则之:依赖倒置原则

1. 依赖倒置原则简介

依赖倒置原则(Dependency Inversion Principle, DIP) 是面向对象设计的核心原则之一,由罗伯特·马丁(Robert C. Martin)提出,旨在降低类间的依赖度,使之更易于维护和扩展。该原则主张高层模块不应该依赖于底层模块,两者都应依赖于抽象接口。

依赖倒置原则强调的是通过引入接口和抽象类来代替直接的类依赖,使得系统设计更灵活,组件间的耦合度更低。这有助于提升系统的整体复用性和扩展性

它要求程序在设计和实现时应该依赖于抽象接口,‌而不是直接依赖于具体的实现。‌依赖倒置原则的实现关键在于抽象进行编程,‌而非对实现进行编程,‌从而使得软件设计更加灵活和可扩展。‌

2. 依赖倒置原则核心思想

依赖倒置原则包含以下三层含义:‌

  1. 高层模块不应该依赖低层模块:‌这里的“高层”和“低层”指的是模块之间的依赖关系。‌按照依赖倒置原则,‌无论是高层模块还是低层模块,‌都应该依赖于抽象,‌而不是直接依赖于具体的实现。‌这样,‌当底层模块发生变化时,‌高层模块不需要进行修改,‌从而提高了系统的可维护性和可扩展性。‌

  2. 抽象不应该依赖细节:‌抽象层(‌如接口或抽象类)‌定义了模块之间的交互规则,‌而不应该依赖于具体的实现细节。‌这意味着抽象层的设计应该独立于具体的实现,‌以便于后续的替换和维护。‌

  3. 细节应该依赖抽象:‌具体的实现类(‌细节)‌应该实现抽象层定义的接口或继承抽象类,‌从而确保它们的行为符合抽象层的规范。‌这样,‌当需要更换具体的实现时,‌只要新的实现类符合抽象层的规范,‌就可以无缝地替换旧的实现类,‌而不需要修改高层模块的代码。‌

依赖倒置原则强调通过依赖于抽象接口而不是具体实现,‌可以减少代码之间的直接依赖,‌使得代码更加模块化、‌可重用,‌并且更容易进行单元测试和维护。‌此外,‌这一原则也是面向对象设计中的一个重要概念,‌它强调了抽象化的重要性,‌并通过抽象化来降低代码之间的耦合度,‌提高软件的质量和可维护性。‌

3. 依赖倒置原则应用场景

  1. 设计模式:例如工厂模式、策略模式等,都是依赖倒置原则的应用实例。
  2. 分层架构:在MVC(模型-视图-控制器)或分层软件体系结构中,每一层依赖于上一层提供的接口或抽象类。
  3. 微服务架构:服务间通过接口通信,而非直接互相依赖。

4. 依赖倒置原则优点

依赖倒置原则(Dependency Inversion Principle, DIP)有以下几个显著的优点:

  1. 高内聚,低耦合:通过依赖于抽象接口或抽象类,降低了组件之间的相互依赖,使得修改或替换底层实现变得更容易,减少了“牵一发而动全身”的风险,提高了代码的独立性和稳定性。

  2. 灵活性:由于高层模块与具体实现解耦,可以方便地添加、删除或替换底层实现,适应不断变化的需求。例如,在测试环境中,可以用模拟实现替代生产环境中的复杂服务。

  3. 模块化与扩展性:每个模块只关心它应该做什么,而不关心是谁在做这件事,这有利于模块的独立开发和维护。新功能的添加通常只需要增加一个新的实现,而不必改动已有的高层模块。

  4. 提高可测试性:因为高层模块不直接依赖于具体实现,它们更容易单元测试。我们可以对每个模块编写单独的测试用例,而不需要担心其他部分的影响。

  5. 减少代码冗余:当需要修改基础逻辑时,只需在一个地方更改接口,所有依赖这个接口的地方都能自动受益,避免了代码复制和粘贴导致的问题。

  6. 符合开闭原则:DIP是开闭原则的具体体现,即对扩展开放,对修改关闭。这意味着增加新的功能时,只需要添加新的实现,而不是修改现有的代码。

5. 依赖倒置原则使用步骤

  1. 定义接口或抽象类:首先,确定业务中共享的行为并创建相应的接口或抽象类。
  2. 抽象高层模块:让高层模块依赖这些接口,而非具体的实现。
  3. 实现接口:创建具体的类并实现这些接口。
  4. 调用者注入依赖:在使用这些高层模块的地方,传入相应的实现对象,而非硬编码。

6. 依赖倒置原则代码示例

// 模型:抽象接口
interface PaymentService {void processPayment();
}// 具体实现:依赖倒置
class CreditCardPaymentService implements PaymentService {@Overridepublic void processPayment() { /* ... */ }
}// 控制器:高层模块,依赖抽象
class ShoppingCartController {private PaymentService paymentService;public ShoppingCartController(PaymentService service) {this.paymentService = service;}public void checkout() {paymentService.processPayment();}
}// 测试时更换支付服务
public class Test {public static void main(String[] args) {ShoppingCartController controller = new ShoppingCartController(new CreditCardPaymentService());// 或者在运行时切换为另一种支付服务controller.paymentService = new PayPalPaymentService();controller.checkout();}
}

7. 总结

综上,依赖倒置原则(Dependency Inversion Principle, DIP)是面向对象设计中的一个基本原则,它提倡高层模块不应该依赖于低层模块,而是两者都应该依赖于抽象。简单来说,就是“针对接口编程,而不是针对实现”。

这个原则鼓励我们编写可测试、灵活和易于维护的代码,通过接口或抽象类来规定系统组件之间的交互,使得当底层实现改变时,高层模块不需要做修改,只需要关注接口的变化即可。这有助于降低系统的耦合度,提高整体架构的稳定性。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • [二次元]个人主页搭建
  • 虚拟化—XenServer安装教程详细(附客户端连接)
  • 注意力机制篇 | YOLOv8改进之引入NAMAttention注意力机制 | 基于标准化的注意力模块
  • 进阶!haproxy高级功能与配置
  • 机器学习(1)--数据可视化
  • 面试实战题-数据库及DAO层
  • 基于STM32设计的智能鱼缸_带鱼儿数量视觉识别(华为云IOT)(202)
  • LeetCode.20.有效的括号
  • 局部场电位LFP
  • 【Python快速入门和实践016】Python常用脚本-对视频抽取指定帧数并保存
  • Oracle(52)分区表有哪些类型?
  • RCE漏洞基础初了解
  • Power Query抓取多页数据导入到Excel
  • C# 解析html
  • FFmpeg源码:av_buffer_is_writable、av_buffer_realloc函数分析
  • 4月23日世界读书日 网络营销论坛推荐《正在爆发的营销革命》
  • CentOS 7 修改主机名
  • Git初体验
  • mysql中InnoDB引擎中页的概念
  • nodejs调试方法
  • SpiderData 2019年2月25日 DApp数据排行榜
  • SpringBoot 实战 (三) | 配置文件详解
  • SwizzleMethod 黑魔法
  • Vue组件定义
  • 大型网站性能监测、分析与优化常见问题QA
  • 当SetTimeout遇到了字符串
  • 海量大数据大屏分析展示一步到位:DataWorks数据服务+MaxCompute Lightning对接DataV最佳实践...
  • 回顾2016
  • 提醒我喝水chrome插件开发指南
  • 网页视频流m3u8/ts视频下载
  • 你对linux中grep命令知道多少?
  • 阿里云ACE认证之理解CDN技术
  • ​【已解决】npm install​卡主不动的情况
  • # MySQL server 层和存储引擎层是怎么交互数据的?
  • # windows 安装 mysql 显示 no packages found 解决方法
  • ## 基础知识
  • ### RabbitMQ五种工作模式:
  • #14vue3生成表单并跳转到外部地址的方式
  • #include<初见C语言之指针(5)>
  • #前后端分离# 头条发布系统
  • #知识分享#笔记#学习方法
  • (3)nginx 配置(nginx.conf)
  • (Demo分享)利用原生JavaScript-随机数-实现做一个烟花案例
  • (DenseNet)Densely Connected Convolutional Networks--Gao Huang
  • (Java)【深基9.例1】选举学生会
  • (博弈 sg入门)kiki's game -- hdu -- 2147
  • (算法)求1到1亿间的质数或素数
  • (转)负载均衡,回话保持,cookie
  • (转)甲方乙方——赵民谈找工作
  • .bat批处理(四):路径相关%cd%和%~dp0的区别
  • .java 9 找不到符号_java找不到符号
  • .net oracle 连接超时_Mysql连接数据库异常汇总【必收藏】
  • .Net(C#)自定义WinForm控件之小结篇
  • .NET/C# 使用反射注册事件
  • .NET4.0并行计算技术基础(1)