引言

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的更多相关文章

  1. 经典设计原则 - SOLID

    SOLID 设计原则包含以下 5 种原则: 单一职责原则(Single Responsibility Principle, SRP) 开闭原则(Open Closed Principle, OCP) ...

  2. 面向对象设计原则-SOLID

    SOLID的意思是: Single responsibility principle 单一职责原则 Open/close principle 开放/封闭原则 Liskov substitution p ...

  3. [设计模式]面向对象五大设计原则:SOLID

    SOLID (面向对象设计) 单一功能原则(Single responsibility principle) 每个类都应该有一个单一的功能,并且该功能应该由这个类完全封装起来 所有它的(这个类的)服务 ...

  4. 【面像对象编程OOP】五种设计原则 Solid

    "面向对象设计五大原则"和良性依赖原则在应付变化方面的作用. SOLID(单一功能.开闭原则.里氏替换.接口隔离以及依赖反转) 单一职责原则(Single-Resposibilit ...

  5. 工作那么久,才知道的 SOLID 设计原则

    认识 SOLID 原则 无论是软件系统设计,还是代码实现,遵循有效和明确的设计原则,都利于系统软件灵活可靠,安全快速的落地,更重要的是能灵活地应对需求,简化系统扩展和维护,避免无效的加班.本文主要讨论 ...

  6. .NET 云原生架构师训练营(设计原则&&设计模式)--学习笔记

    目录 设计原则 设计模式 设计原则 DRY (Don't repeat yourself 不要重复) KISS (Keep it stupid simple 简单到傻子都能看懂) YAGNI (You ...

  7. JavaScript设计原则与编程技巧

    1 设计原则概述 <UNIX/LINUX设计哲学>设计准则 ① 小既是美. ② 每个程序只做一件事情. ③ 快速建立原型. ④ 舍弃高效率而取可移植性. ⑤ 避免强制性的图形化界面交互. ...

  8. 聊聊OOP中的设计原则以及访问者模式

    一  设计原则 (SOLID) 1.  S - 单一职责原则(Single Responsibllity Principle) 1.1  定义 一个类或者模块只负责完成一个职责(或功能), 认为&qu ...

  9. 软件设计原则(Principles)

    设计模式的从许多优秀的软件中总结出来的 , 使用设计模式能够实现可复用.可维护.开发人员之间方便沟通设计和理解代码. Tips 对于模式的使用 , 不能拘泥于格式 , 事实上根据需要模式是可以演化的 ...

  10. SOLID 设计原则

    SOLID 原则基本概念: 程序设计领域, SOLID (单一功能.开闭原则.里氏替换.接口隔离以及依赖反转)是由罗伯特·C·马丁在21世纪早期 引入的记忆术首字母缩略字,指代了面向对象编程和面向对象 ...

随机推荐

  1. 【云原生】为什么要虚拟化,为什么要容器,为什么要Docker,为什么要K8S?

    前言 如标题中的问题所提到的虚拟化,容器,Docker和K8s那样,我们不妨这样问:这些技术到底适用于哪些场景,有没有别的技术可以替代?这些技术的优劣在哪里? 下面我将针对性地从以上几个问题的出发点, ...

  2. NLP领域任务如何选择合适预训练模型以及选择合适的方案【规范建议】【ERNIE模型首选】

    1.常见NLP任务 信息抽取:从给定文本中抽取重要的信息,比如时间.地点.人物.事件.原因.结果.数字.日期.货币.专有名词等等.通俗说来,就是要了解谁在什么时候.什么原因.对谁.做了什么事.有什么结 ...

  3. 46从零开始用Rust编写nginx,数据还能这么传,多层代理(IP多级代理)搭建

    wmproxy wmproxy已用Rust实现http/https代理, socks5代理, 反向代理, 负载均衡, 静态文件服务器,websocket代理,四层TCP/UDP转发,内网穿透等,会将实 ...

  4. LeetCode刷题日记 2020/03/26

    题干 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb" 输出: 3 解释: 因为无重复字符的最长子串是 "abc ...

  5. html 图片地图

    <html> <head> <title></title> </head> <body> <img src="8 ...

  6. 零基础入门学习Java课堂笔记 ——day04

    Java数组 1.数组概述 定义:数组是相同类型的有序集合,同一组同一类型的数据可以按照先后次序排列组合在一起,其中一个数据可以称为元素,每个数组元素可以通过一个下表访问它们 2.数组声明创建 dat ...

  7. Flink CDC写入数据到kafka几种格式

    Flink CDC写入kafka几种常见的数据格式,其中包括upsert-kafka写入后正常的json格式,debezium-json格式以及changelog-json格式. upsert-kaf ...

  8. docker离线安装及设置默认存储目录

    一.离线安装Docker 在内网环境下,一般不能联网在线部署,这时候就需要以离线的方式安装docker.本文介绍在CentOS 7.6环境中离线安装docker的步骤. 1. 下载docker安装包 ...

  9. CF1902

    A 只要不是全 \(1\) 即可. B 二分完成天数. C \(x\) 取差的 \(gcd\),\(a_{n+1}\) 见缝插针. D 用一个 map 记录按原始操作序列,要走到 \((x,y)\) ...

  10. NC14700 追债之旅

    题目链接 题目 题目描述 小明现在要追讨一笔债务,已知有n座城市,每个城市都有编号,城市与城市之间存在道路相连(每条道路都是双向的),经过任意一条道路需要支付费用.小明一开始位于编号为1的城市,欠债人 ...