设计原则 --- SOLID
引言
SOLID是五个常见的面向对象设计原则的缩写,其目的是帮助开发者设计易于维护和扩展的软件系统
其中包含单一职责原则(SRP),开闭原则(OCP),里氏替换原则(LSP),接口隔离原则(ISP),依赖反转原则(DIP)。
除SOLID之外,后续又增加了迪米特法则。
单一职责原则
单一职责原则(Single Responsibility Principle,SRP),这个原则指出一个类应该只有一个职责。也就是说,一个类应该只有一种修改的原因。如果一个类负责多个不同的职责,那么对其中一个职责的修改可能会影响到其他职责,从而导致系统的不稳定性。
开闭原则
开闭原则(Open-Closed Principle,OCP),这个原则指出一个类应该对扩展开放,对修改关闭。也就是说,系统中的类应该能够方便地进行扩展,但是对于已经存在的类,尽量避免进行修改。这样可以减少代码的复杂性,提高系统的稳定性。
:::tip{title="提示"}
开闭原则需要避免过度设计,即在不必要的情况下进行扩展。同时,应该避免使用复杂的继承结构,而应该优先使用组合和接口实现扩展。
:::
里氏替换原则
里氏替换原则(Liskov Substitution Principle,LSP),这个原则指出,如果一个子类不能完全替代它的父类,那么这个子类就不应该存在。换句话说,子类应该能够在不影响父类的前提下,完全替代父类的功能。这样才能保证系统的正确性和稳定性。
:::tip{title="提示"}
里氏替换原则需要注意继承关系的正确性。子类必须要遵循父类的约束,否则就会破坏LSP的原则。同时,在使用多态时需要注意类型的转换和类型检查的正确性。
:::
接口隔离原则
接口隔离原则(Interface Segregation Principle,ISP),这个原则指出一个类不应该强制依赖它不需要的接口。如果一个类依赖了一个过于庞大的接口,那么当这个接口发生变化时,这个类也需要相应地进行修改。因此,一个类应该尽量只依赖于它需要的接口,避免不必要的依赖。
:::tip{title="提示"}
接口隔离原则需要避免接口的冗余和重复。接口应该根据不同的职责进行分离,避免一个接口承担过多的职责。同时,应该避免使用过于具体的接口,而应该优先使用更抽象的接口
:::
依赖反转原则
依赖反转原则(Dependency Inversion Principle,DIP),这个原则指出,高层模块不应该依赖于低层模块,两者都应该依赖于抽象。同时,抽象不应该依赖于具体实现,具体实现应该依赖于抽象。这样可以减少系统的耦合度,提高系统的可扩展性和可维护性。
:::tip{title="提示"}
依赖反转原则需要注意依赖注入的方式和依赖倒置的层次。依赖注入应该使用构造函数注入、属性注入或方法注入,避免使用硬编码的依赖。同时,在依赖倒置时需要注意依赖的层次,避免高层模块依赖过于低层的模块。
:::
迪米特法则
迪米特法则(Law of Demeter,LoD)也称为最少知识原则(Least Knowledge Principle,LKP)。
迪米特法则要求一个对象应该只与其直接的朋友通信,而不是跟朋友的朋友或者更远的对象通信。对象之间的耦合度越低,系统的灵活性、可维护性、可扩展性就越好,同时也降低了代码的复杂度和风险。
:::tip{title="提示"}
迪米特法则需要注意:
- 将方法中的参数尽量缩小,尽量不引入不需要的对象。
- 在类的设计中,尽量降低对其他类的依赖。
- 将依赖其他类的操作放到一个中介类中,由中介类负责和其他类的通信。
:::
结论
SOLID原则是一种很好的软件设计指导原则,能够帮助开发者设计出易于维护和扩展的软件系统。但是,这些原则并不是银弹,需要根据具体的情况进行灵活运用。同时,在应用这些原则时需要注意细节和实现细节,才能真正达到SOLID原则的设计目标。
设计原则 --- SOLID的更多相关文章
- 经典设计原则 - SOLID
SOLID 设计原则包含以下 5 种原则: 单一职责原则(Single Responsibility Principle, SRP) 开闭原则(Open Closed Principle, OCP) ...
- 面向对象设计原则-SOLID
SOLID的意思是: Single responsibility principle 单一职责原则 Open/close principle 开放/封闭原则 Liskov substitution p ...
- [设计模式]面向对象五大设计原则:SOLID
SOLID (面向对象设计) 单一功能原则(Single responsibility principle) 每个类都应该有一个单一的功能,并且该功能应该由这个类完全封装起来 所有它的(这个类的)服务 ...
- 【面像对象编程OOP】五种设计原则 Solid
"面向对象设计五大原则"和良性依赖原则在应付变化方面的作用. SOLID(单一功能.开闭原则.里氏替换.接口隔离以及依赖反转) 单一职责原则(Single-Resposibilit ...
- 工作那么久,才知道的 SOLID 设计原则
认识 SOLID 原则 无论是软件系统设计,还是代码实现,遵循有效和明确的设计原则,都利于系统软件灵活可靠,安全快速的落地,更重要的是能灵活地应对需求,简化系统扩展和维护,避免无效的加班.本文主要讨论 ...
- .NET 云原生架构师训练营(设计原则&&设计模式)--学习笔记
目录 设计原则 设计模式 设计原则 DRY (Don't repeat yourself 不要重复) KISS (Keep it stupid simple 简单到傻子都能看懂) YAGNI (You ...
- JavaScript设计原则与编程技巧
1 设计原则概述 <UNIX/LINUX设计哲学>设计准则 ① 小既是美. ② 每个程序只做一件事情. ③ 快速建立原型. ④ 舍弃高效率而取可移植性. ⑤ 避免强制性的图形化界面交互. ...
- 聊聊OOP中的设计原则以及访问者模式
一 设计原则 (SOLID) 1. S - 单一职责原则(Single Responsibllity Principle) 1.1 定义 一个类或者模块只负责完成一个职责(或功能), 认为&qu ...
- 软件设计原则(Principles)
设计模式的从许多优秀的软件中总结出来的 , 使用设计模式能够实现可复用.可维护.开发人员之间方便沟通设计和理解代码. Tips 对于模式的使用 , 不能拘泥于格式 , 事实上根据需要模式是可以演化的 ...
- SOLID 设计原则
SOLID 原则基本概念: 程序设计领域, SOLID (单一功能.开闭原则.里氏替换.接口隔离以及依赖反转)是由罗伯特·C·马丁在21世纪早期 引入的记忆术首字母缩略字,指代了面向对象编程和面向对象 ...
随机推荐
- 【scikit-learn基础】--『回归模型评估』之准确率分析
分类模型的评估和回归模型的评估侧重点不一样,回归模型一般针对连续型的数据,而分类模型一般针对的是离散的数据. 所以,评估分类模型时,评估指标与回归模型也很不一样,比如,分类模型的评估指标通常包括准确率 ...
- 紧跟潮流,抓住趋势,跟上全民AI的节奏,开源IM项目OpenIM产品介绍,为AIGC贡献力量
开源价值 高度自主.安全可控.开放自由,私有化部署,一切皆可控 透明度和可信度:开源软件的源代码是公开的,任何人都可以查看和检查代码,从而增强了软件的透明度和可信度.用户可以了解软件的内部结构和运作方 ...
- C# Contains()、 == 和Equals() 比较
目前在开发中前端页面有搜索条件 和后端的方法进行匹配 有一个Student表,其中有字段:name.age.address.tel CREATE TABLE Student ( Name varcha ...
- 2.1 Windows驱动开发:内核链表与结构体
在Windows内核中,为了实现高效的数据结构操作,通常会使用链表和结构体相结合的方式进行数据存储和操作.内核提供了一个专门用于链表操作的数据结构LIST_ENTRY,可以用来描述一个链表中的每一个节 ...
- 嫌 OSS 查询太慢?看我们如何将速度提升 10 倍!
背景 HDFS 是 Hadoop 生态的默认存储系统,很多数据分析和管理工具都是基于它的 API 设计和实现的.但 HDFS 是为传统机房设计的,在云上维护 HDFS 一点也不轻松,需要投入不少人力进 ...
- Oracle多租户架构之如何快速创建一个PDB
Oracle自从12c版本开始引入多租户的架构,整个管理理念也发生了很大的变化. 比如之前再小的业务只要选择了Oracle,DBA都会选择新建一套独立的数据库,因为传统的架构只能在schema级别作区 ...
- 【MFC学习二】CFileDialog导出文件
用CFileDialog导出文件,用户可指定文件名后缀等,感觉操作上比上文的 BROWSEINFO 更加人性化. //将数据项写入CSV文件 int PutCSVItemLine(FILE *file ...
- [JVM]逃逸分析
逃逸分析 JVM的内存分配策略 首先回顾一下JVM的内存分配策略. JVM的内存包括方法区.堆.虚拟机栈.本地方法栈.程序计数器.一般情况下JVM运行时的数据都是存在栈和堆上的.栈用来存放一些基本变量 ...
- 【.NET】聊聊 IChangeToken 接口
由于两个月的奋战,导致很久没更新了.就是上回老周说的那个产线和机械手搬货的项目,好不容易等到工厂放假了,我就偷偷乐了.当然也过年了,老周先给大伙伴们拜年了,P话不多讲,就祝大家身体健康.生活愉快.其实 ...
- 多线程系列(三) -synchronized 关键字使用详解
一.简介 在之前的线程系列文章中,我们介绍了线程创建的几种方式以及常用的方法介绍. 今天我们接着聊聊多线程线程安全的问题,以及解决办法. 实际上,在多线程环境中,难免会出现多个线程对一个对象的实例变量 ...