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

架构设计基本原则

开闭原则

开闭原则(Open Closed Principle,OCP)是面向对象编程(OOP)中的一个核心原则,主要强调的是软件实体(类、模块、函数等)应该对扩展开放,对修改封闭。

解释:

这个原则的主要思想是设计软件时,应该允许其功能或行为可以通过添加新代码来扩展,而不是通过修改现有的代码来实现。换句话说,一旦一个软件系统被部署后,应该尽可能地避免修改它的源代码,而是通过添加新的代码来实现系统的升级和扩展。这样做的好处是可以保证系统的稳定性和可维护性。

重要性:

  1. 稳定性: 遵循开闭原则可以确保已有的系统或组件在扩展时不会破坏或影响其他部分的功能。
  2. 可维护性: 当系统需要新增功能时,不需要修改原有的代码,这降低了维护成本和风险。
  3. 灵活性: 此原则鼓励开发者设计出灵活且易于扩展的系统,使得未来的变化更加容易实现。
  4. 复用性: 由于系统组件间的耦合度降低,提高了组件的复用性。

实现方法:

  • 抽象化设计: 使用抽象类或接口来定义系统的行为,这样具体的实现可以随时被替换或扩展。
  • 封装变化: 识别可能发生变化的部分,并将其封装起来,以便隔离变化的影响。
  • 使用设计模式: 如工厂模式、策略模式等,这些设计模式可以帮助实现系统的灵活性和可扩展性。

单一职责原则

单一职责原则(Single Responsibility Principle,简称SRP)是面向对象编程中SOLID原则之一,它规定一个类或模块应该只负责一项职责。

解释:

这一原则的核心思想是,每个类应该只有一个引起它变化的原因。换句话说,类的职责应当单一,不应该是多方面的。如果一个类承担了过多的职责,不仅会导致其变得庞大和复杂,还可能导致不同职责之间的耦合增加,这在软件的维护和扩展过程中会引起问题。

重要性:

  1. 降低复杂度: 当类的职责单一时,它的结构和行为相对简单,更容易理解和实现。
  2. 提高可读性和可维护性: 职责单一的类更容易被其他开发者理解,修改和扩展时也更加安全。
  3. 解耦: 单一职责原则自然地促进了系统内部的解耦,因为类之间的依赖关系变得更加清晰。
  4. 灵活性和可复用性: 由于类的功能专一,它们在应用程序中的复用变得更加容易。

实现方法:

  • 明确界定职责: 在设计类时,仔细考虑其职责,确保每个类只处理一件事情。
  • 功能分解: 分析功能需求,将不同的功能划分到不同的类中去。
  • 遵循“高内聚低耦合”的设计: 高内聚意味着类的内部功能紧密相关,而低耦合则表示类与类之间的关系简单明了。

单一职责原则不仅适用于类的设计,同样也适用于模块、函数等软件的其他组成部分。通过遵循这一原则,可以显著提高软件的质量和可维护性。

里氏替换原则

里氏替换原则(Liskov Substitution Principle,简称LSP)是面向对象编程中SOLID原则之一,由计算机科学家芭芭拉·利斯科夫(Barbara Liskov)提出。这一原则的核心思想是确保对象可以被其子类型无歧义地替换,而不会影响到程序的正确性。

解释:

在面向对象的继承关系中,子类继承了父类的属性和行为,并可以扩展或重写这些行为。里氏替换原则要求子类在扩展父类时,必须保证不会改变父类的行为契约,即子类的所有实例应该能够被替换为父类的实例,而不会导致程序在运行时出现错误。

重要性:

  1. 保持系统的稳定性: 遵循LSP的系统更加稳定,因为子类的正确实现保证了父类期望的行为。
  2. 提高代码的可理解性和可预测性: 当子类保证遵守父类的约定时,使用这些类的代码变得更加容易理解和预测。
  3. 减少bug的可能性: 正确应用LSP可以减少由于不当的子类实现导致的程序错误。
  4. 促进良好的设计实践: 遵守LSP鼓励开发者设计出更加健壮和灵活的类层次结构。

实现方法:

  • 遵守预条件和后条件: 子类的方法实现需要满足父类方法的预条件和后条件。
  • 避免改变方法的签名: 子类不应该修改父类中已有方法的签名。
  • 确保兼容性: 子类重写或扩展父类的行为时,应保证新行为的兼容性,不违背父类定义的行为契约。
  • 使用设计模式: 某些设计模式如适配器模式可以帮助实现LSP,通过适配器来保证不同的子类可以无缝地替换使用。

正确地应用里氏替换原则是确保面向对象软件系统可维护性和扩展性的关键因素之一。

迪米特法则

迪米特法则(Law of Demeter,简称LoD),也称为“最少知识原则”,是面向对象编程中的一种设计原则,旨在减少类之间的耦合。

解释:

迪米特法则的核心思想是,一个类应该尽量少的了解其他类的信息,即一个对象应当对其他对象有尽可能少的了解。这样,类之间的交互被限制在必须的范围内,从而降低了系统的耦合度,提高了模块的独立性和可维护性。

重要性:

  1. 降低耦合: 通过限制类之间的交互,减少了它们之间的依赖关系,使得每个类更加独立。
  2. 提高可维护性: 当类之间的耦合度降低时,修改一个类的实现不太可能影响到其他类,从而降低了维护成本。
  3. 增强模块的可复用性: 由于依赖性的减少,各个类或模块更容易在不同的项目或环境中复用。
  4. 提升系统的稳定性: 系统的各个部分相互独立,一部分的变动不会影响到其他部分,从而提高了系统的整体稳定性。

实现方法:

  • 限制直接访问: 避免让一个类直接访问另一个类的私有属性或方法,应该通过公共接口进行交互。
  • 使用消息传递: 对象之间通过发送消息(调用公共方法)来通信,而不是直接操作对方的内部状态。
  • 减少方法的参数: 方法的参数应该是完成该方法所需的最小接口,避免传递整个对象仅仅为了访问其一小部分数据。
  • 遵循“朋友类”概念: 如果两个类需要更紧密的交互,可以将它们设计为“朋友类”,即允许特定的类访问另一些类的更多内部细节。

迪米特法则有助于指导开发者设计出更加清晰、松散耦合的系统,这对于大型软件项目尤其重要。

接口隔离原则

接口隔离原则(Interface Segregation Principle,简称ISP)是面向对象编程中SOLID原则之一,它强调接口的细化和客户的需要。

解释:

接口隔离原则的主要思想是,不应该强迫客户依赖于它们不使用的方法或功能。换句话说,接口应该细分到客户需要的程度,即每个接口应该只声明与特定用例相关的方法。这样,实现接口的类就不需要提供那些与特定用例无关的方法实现,从而减少了系统的复杂度和耦合度。

重要性:

  1. 提高可维护性: 当接口专注于特定的功能时,任何修改都只会影响实现该接口的类,而不会影响到其他不相关的类。
  2. 增强可读性和易用性: 接口越小,越容易理解和使用。用户可以快速地找到他们需要的方法,而不会被不相关的方法干扰。
  3. 减少冗余代码: 由于接口更加细化,实现类不需要为那些与它们不相关的功能提供空方法或者默认实现,从而减少了冗余代码。
  4. 提升灵活性: 细化的接口更容易扩展和维护。当系统需求变化时,可以更容易地添加新的接口来满足新的需求,而不是修改现有的大接口。

实现方法:

  • 了解用户需求: 在设计接口时,首先要清楚地了解不同用户的需求,以便为不同的用例提供合适的接口。
  • 细分接口: 根据功能的不同将大接口拆分成多个小接口,每个接口只包含一组逻辑上相关的方法和属性。
  • 优先考虑用户接口: 在设计类的时候,优先考虑用户会如何使用这个类,而不是从类的内部实现出发。
  • 延迟实现: 如果一个接口的某些方法对某些实现类来说没有意义,那么这些方法可以在这些实现类中保持未实现或者声明为抽象方法。

接口隔离原则是促进软件组件之间健康解耦的重要原则之一,它鼓励开发者创建更加灵活、可维护的系统。

依赖倒置原则

依赖倒置原则(Dependency Inversion Principle,简称DIP)是面向对象编程中SOLID原则之一,它指导我们如何管理类之间的依赖关系。

解释:

依赖倒置原则的核心思想是高层模块不应该依赖于低层模块,它们都应该依赖于抽象。同时,抽象不应该依赖于具体实现细节,而具体实现应该依赖于抽象。这样,系统的设计更加稳定,因为高层业务逻辑与低层具体实现的改动被隔离开了。

重要性:

  1. 提高代码的可维护性: 当高层模块不直接依赖于低层模块时,对低层模块的修改不会影响到高层模块,减少了维护成本。
  2. 增强系统的灵活性: 依赖倒置原则使得系统更容易扩展和修改,因为高层和低层模块之间的耦合度降低了。
  3. 促进模块间解耦: 通过依赖于抽象,模块间的依赖关系变得更加清晰,模块可以独立地开发和测试。
  4. 提升代码的可复用性: 抽象和具体实现的分离使得代码更加易于复用,因为具体的实现可以在不同的上下文中被替换或重用。

实现方法:

  • 定义抽象接口: 为系统中的关键功能定义抽象接口,这些接口将作为不同模块之间通信的契约。
  • 高层模块声明接口: 高层模块声明需要使用的接口,但不关心接口的具体实现。
  • 低层模块实现接口: 低层模块实现高层模块声明的接口,从而提供具体的功能。
  • 使用依赖注入: 依赖注入是一种常用的实现依赖倒置原则的技术,它允许将依赖的实例在运行时动态注入到使用它的对象中。

依赖倒置原则是实现面向对象设计原则中“倒置”的部分,它帮助我们构建出更加灵活、稳定和可维护的软件系统。

相关文章:

架构设计基本原则

开闭原则 开闭原则(Open Closed Principle,OCP)是面向对象编程(OOP)中的一个核心原则,主要强调的是软件实体(类、模块、函数等)应该对扩展开放,对修改封闭。 解释&…...

云原生应用开发培训,开启云计算时代的新征程

在云计算时代,云原生应用开发技术已经成为IT领域的热门话题。如果您想要转型至云原生领域,我们的云原生应用开发培训将帮助您开启新征程。 我们的课程内容涵盖了云原生技术的基础概念、容器技术、微服务架构、持续集成与持续发布(CI/CD&#…...

【数据库设计】宠物商店管理系统

目录 🌊1 问题的提出 🌊2 需求分析 🌍2.1 系统目的 🌍2.2 用户需求 🌻2.2.1 我国宠物行业作为新兴市场,潜力巨大 🌻2.2.2 我国宠物产品消费规模逐年增大 🌻2.2.3 我国宠物主选…...

前端 JS 经典:node 的模块查找策略

前言:我们引入模块后,node 大概的查找步骤分为 文件查找、文件夹查找、内置模块查找、第三方模块查找,在 node 中使用 ESM 模块语法,需要创建 package.json 文件,并将 type 设置为 module。简单起见,我们用…...

C++中的23种设计模式

目录 摘要 创建型模式 1. 工厂方法模式(Factory Method Pattern) 2. 抽象工厂模式(Abstract Factory Pattern) 3. 单例模式(Singleton Pattern) 4. 生成器模式(Builder Pattern&#xff0…...

vue.js+node.js+mysql在线聊天室源码

vue.jsnode.jsmysql在线聊天室源码 技术栈:vue.jsElement UInode.jssocket.iomysql vue.jsnode.jsmysql在线聊天室源码...

浏览器无痕模式和非无痕模式的区别

无痕模式 1. 历史记录:在无痕模式下,浏览器不会保存浏览记录、下载记录、表单数据和Cookies。当你关闭无痕窗口后,这些信息都会被删除。
 2. Cookies:无痕模式会在会话期间临时存储Cookies,但在关闭无痕窗口…...

WPF框架,修改ComboBox控件背景色 ,为何如此困难?

直接修改Background属性不可行 修改控件背景颜色,很多人第一反应便是修改Background属性,但是修改过后便会发现,控件的颜色没有发生任何变化。 于是在网上搜索答案,便会发现一个异常尴尬的情况,要么就行代码简单但是并…...

Diffusers代码学习: 文本引导深度图像生成

StableDiffusionDepth2ImgPipeline允许传递文本提示和初始图像,以调节新图像的生成。此外,还可以传递depth_map以保留图像结构。如果没有提供depth_map,则管道通过集成的深度估计模型自动预测深度。 # 以下代码为程序运行进行设置 import o…...

网络的下一次迭代:AVS 将为 Web2 带去 Web3 的信任机制

撰文:Sumanth Neppalli,Polygon Ventures 编译:Yangz,Techub News 本文来源香港Web3媒体:Techub News AVS (主动验证服务)将 Web2 的规模与 Web3 的信任机制相融合,开启了网络的下…...

OpenCV 的模板匹配

OpenCV中的模板匹配 模板匹配(Template Matching)是计算机视觉中的一种技术,用于在大图像中找到与小图像(模板)相匹配的部分。OpenCV提供了多种模板匹配的方法,主要包括基于相关性和基于平方差的匹配方法。…...

26.0 Http协议

1. http协议简介 HTTP(Hypertext Transfer Protocol, 超文本传输协议): 是万维网(WWW: World Wide Web)中用于在服务器与客户端(通常是本地浏览器)之间传输超文本的协议.作为一个应用层的协议, HTTP以其简洁, 高效的特点, 在分布式超媒体信息系统中扮演着核心角色. 自1990年提…...

IO流打印流

打印流 IO流打印流是Java中用来将数据打印到输出流的工具。打印流提供了方便的方法来格式化和输出数据,可以用于将数据输出到控制台、文件或网络连接。 分类:打印流一般是指:PrintStream,PrintWriter两个类 特点1:打印流只操作文件目的地,…...

Cohere reranker 一致的排序器

这本notebook展示了如何在检索器中使用 Cohere 的重排端点。这是在 ContextualCompressionRetriever 的想法基础上构建的。 %pip install --upgrade --quiet cohere %pip install --upgrade --quiet faiss# OR (depending on Python version)%pip install --upgrade --quiet…...

MySQL系列-语法说明以及基本操作(二)

1、MySQL数据表的约束 1.1、MySQL主键 “主键(PRIMARY KEY)”的完整称呼是“主键约束”。 MySQL 主键约束是一个列或者列的组合,其值能唯一地标识表中的每一行。这样的一列或多列称为表的主键,通过它可以强制表的实体完整性。 …...

【STM32】步进电机及其驱动

设计和实现基于STM32微控制器的步进电机驱动系统是一个涉及硬件设计、固件编程和电机控制算法的复杂任务。以下是一个概要设计,包括一些基本的代码示例。 1. 硬件设计 1.1 微控制器选择 选择STM32系列微控制器,因为它提供了丰富的GPIO端口和足够的处理…...

Excel自定义排序和求和

概览 excel作为办公的常备工具,好记性不如烂笔头,在此梳理记录下,此篇文章主要是记录excel的自定义排序和求和 一. 自定义排序 举个例子 1. 填充自定义排序选项 实现步骤: 选定目标排序值;文件->选项->自定…...

若依RuoYi-Vue分离版—免登录直接访问

若依RuoYi-Vue分离版—免登录直接访问 如何不登录直接访问前端:后端:方法1:在SecurityConfig.java中设置httpSecurity配置匿名访问方法2:在对应的方法或类上面使用Anonymous注解。 如何不登录直接访问 官网有说明:如何不登录直接…...

java基础知识漏洞记录一

下面是我在阅读JavaGuide面试资料时遇到的不熟悉的知识点总结 JDK9中JRE与JDK新关系 从 JDK 9 开始,就不需要区分 JDK 和 JRE 的关系了,取而代之的是模块系统(JDK 被重新组织成 94 个模块) jlink 工具 (随 Java 9 一起发布的新命…...

html的网页制作代码分享

<!-- prj_8_2.html --> <!DOCTYPE html> <html lang "EN"><head><meta charset"utf-8" /><title>页面布局设计</title><style type "text/css">*{padding: 0px;margin:0px;}#header{back…...

label-studio的使用教程(导入本地路径)

文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…...

YSYX学习记录(八)

C语言&#xff0c;练习0&#xff1a; 先创建一个文件夹&#xff0c;我用的是物理机&#xff1a; 安装build-essential 练习1&#xff1a; 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件&#xff0c;随机修改或删除一部分&#xff0c;之后…...

Qwen3-Embedding-0.6B深度解析:多语言语义检索的轻量级利器

第一章 引言&#xff1a;语义表示的新时代挑战与Qwen3的破局之路 1.1 文本嵌入的核心价值与技术演进 在人工智能领域&#xff0c;文本嵌入技术如同连接自然语言与机器理解的“神经突触”——它将人类语言转化为计算机可计算的语义向量&#xff0c;支撑着搜索引擎、推荐系统、…...

在Ubuntu中设置开机自动运行(sudo)指令的指南

在Ubuntu系统中&#xff0c;有时需要在系统启动时自动执行某些命令&#xff0c;特别是需要 sudo权限的指令。为了实现这一功能&#xff0c;可以使用多种方法&#xff0c;包括编写Systemd服务、配置 rc.local文件或使用 cron任务计划。本文将详细介绍这些方法&#xff0c;并提供…...

【单片机期末】单片机系统设计

主要内容&#xff1a;系统状态机&#xff0c;系统时基&#xff0c;系统需求分析&#xff0c;系统构建&#xff0c;系统状态流图 一、题目要求 二、绘制系统状态流图 题目&#xff1a;根据上述描述绘制系统状态流图&#xff0c;注明状态转移条件及方向。 三、利用定时器产生时…...

3-11单元格区域边界定位(End属性)学习笔记

返回一个Range 对象&#xff0c;只读。该对象代表包含源区域的区域上端下端左端右端的最后一个单元格。等同于按键 End 向上键(End(xlUp))、End向下键(End(xlDown))、End向左键(End(xlToLeft)End向右键(End(xlToRight)) 注意&#xff1a;它移动的位置必须是相连的有内容的单元格…...

ip子接口配置及删除

配置永久生效的子接口&#xff0c;2个IP 都可以登录你这一台服务器。重启不失效。 永久的 [应用] vi /etc/sysconfig/network-scripts/ifcfg-eth0修改文件内内容 TYPE"Ethernet" BOOTPROTO"none" NAME"eth0" DEVICE"eth0" ONBOOT&q…...

纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join

纯 Java 项目&#xff08;非 SpringBoot&#xff09;集成 Mybatis-Plus 和 Mybatis-Plus-Join 1、依赖1.1、依赖版本1.2、pom.xml 2、代码2.1、SqlSession 构造器2.2、MybatisPlus代码生成器2.3、获取 config.yml 配置2.3.1、config.yml2.3.2、项目配置类 2.4、ftl 模板2.4.1、…...

什么是VR全景技术

VR全景技术&#xff0c;全称为虚拟现实全景技术&#xff0c;是通过计算机图像模拟生成三维空间中的虚拟世界&#xff0c;使用户能够在该虚拟世界中进行全方位、无死角的观察和交互的技术。VR全景技术模拟人在真实空间中的视觉体验&#xff0c;结合图文、3D、音视频等多媒体元素…...

热烈祝贺埃文科技正式加入可信数据空间发展联盟

2025年4月29日&#xff0c;在福州举办的第八届数字中国建设峰会“可信数据空间分论坛”上&#xff0c;可信数据空间发展联盟正式宣告成立。国家数据局党组书记、局长刘烈宏出席并致辞&#xff0c;强调该联盟是推进全国一体化数据市场建设的关键抓手。 郑州埃文科技有限公司&am…...