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

设计模式基础与SOLID原则

️ 设计模式基础与SOLID原则设计模式是软件开发中经过验证的、可复用的解决方案。掌握设计模式能够让我们的代码更加优雅、可维护、可扩展。一、什么是设计模式设计模式Design Pattern是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。设计模式的核心思想是在特定环境下解决软件设计中某类通用问题的方案。它不是可以直接复制粘贴的代码而是一种解决问题的思路和方法论。 设计模式的本质价值价值维度说明可复用性避免重复造轮子站在巨人的肩膀上可维护性遵循统一的模式代码结构清晰易懂可扩展性方便添加新功能减少对现有代码的修改沟通效率提供统一的术语团队沟通更高效二、设计模式的三大分类根据设计模式的用途可以将其分为三大类创建型模式、结构型模式和行为型模式。2.1 创建型模式5种创建型模式关注对象的创建过程将对象的创建和使用分离降低系统的耦合度。模式名称核心思想适用场景工厂方法模式定义一个创建对象的接口让子类决定实例化哪一个类需要根据条件创建不同对象抽象工厂模式提供一个创建一系列相关或相互依赖对象的接口需要创建产品族单例模式确保一个类只有一个实例并提供全局访问点配置管理器、连接池、日志对象建造者模式将一个复杂对象的构建与它的表示分离创建复杂对象如配置项较多的对象原型模式通过复制现有对象来创建新对象创建成本较高的对象2.2 结构型模式7种结构型模式关注类和对象的组合通过继承或组合来构建更大的结构。模式名称核心思想适用场景适配器模式将一个类的接口转换成客户希望的另一个接口接口不兼容时进行转换装饰器模式动态地给一个对象添加一些额外的职责不通过继承扩展对象功能代理模式为其他对象提供一种代理以控制对这个对象的访问远程代理、虚拟代理、保护代理外观模式为子系统中的一组接口提供一个一致的界面简化复杂系统的使用桥接模式将抽象部分与实现部分分离使它们都可以独立变化多维度变化的对象组合模式将对象组合成树形结构以表示部分-整体的层次结构树形结构数据处理享元模式运用共享技术有效地支持大量细粒度的对象大量相似对象的共享2.3 行为型模式11种行为型模式关注对象之间的通信、职责划分以及算法的封装。模式名称核心思想适用场景策略模式定义一系列算法把它们一个个封装起来并且使它们可相互替换多种算法可互换模板方法模式定义一个操作中的算法骨架而将一些步骤延迟到子类中固定流程具体步骤可变观察者模式定义对象间一对多的依赖关系当一个对象状态改变时所有依赖它的对象都得到通知事件驱动系统迭代器模式提供一种方法顺序访问一个聚合对象中各个元素而又不需暴露该对象的内部表示遍历集合责任链模式使多个对象都有机会处理请求从而避免请求的发送者和接收者之间的耦合关系多级审批、事件处理链命令模式将一个请求封装为一个对象从而使你可用不同的请求对客户进行参数化撤销/重做操作备忘录模式在不破坏封装性的前提下捕获一个对象的内部状态并在该对象之外保存这个状态撤销操作、游戏存档状态模式允许一个对象在其内部状态改变时改变它的行为状态机实现访问者模式表示一个作用于某对象结构中的各元素的操作数据结构与操作分离中介模式用一个中介对象来封装一系列的对象交互对象间复杂交互解释器模式给定一个语言定义它的文法的一种表示并定义一个解释器SQL解析、正则表达式三、SOLID原则详解SOLID是面向对象设计的五大基本原则的首字母缩写由Robert C. MartinUncle Bob提出。这些原则是设计模式的理论基础理解它们对于正确使用设计模式至关重要。3.1 单一职责原则Single Responsibility Principle, SRP定义一个类应该只有一个引起它变化的原因。核心思想每个类只负责一项职责不要将多个职责耦合在一个类中。// ❌ 违反单一职责原则classUser{public:voidlogin(){/* 登录逻辑 */}voidsaveToDatabase(){/* 数据库存储逻辑 */}voidsendEmail(){/* 发送邮件逻辑 */}};// ✅ 遵循单一职责原则classUser{public:voidlogin(){/* 登录逻辑 */}};classUserRepository{public:voidsave(User user){/* 数据库存储逻辑 */}};classEmailService{public:voidsend(User user){/* 发送邮件逻辑 */}};实际经验如果一个类的方法超过10个或者代码超过300行就需要考虑是否职责过多职责的划分粒度需要根据实际项目规模来定不要过度拆分3.2 开闭原则Open-Closed Principle, OCP定义软件实体应该对扩展开放对修改关闭。核心思想在不修改现有代码的情况下通过扩展来增加新功能。// ✅ 通过抽象实现开闭原则classShape{public:virtualdoublearea()0;virtual~Shape()default;};classRectangle:publicShape{doublewidth,height;public:doublearea()override{returnwidth*height;}};classCircle:publicShape{doubleradius;public:doublearea()override{return3.14159*radius*radius;}};// 新增三角形不需要修改现有代码classTriangle:publicShape{doublebase,height;public:doublearea()override{return0.5*base*height;}};实际经验使用抽象和多态是实现开闭原则的主要手段设计时要预见可能的变化点提前做好抽象3.3 里氏替换原则Liskov Substitution Principle, LSP定义所有引用基类的地方必须能透明地使用其子类的对象。核心思想子类必须能够替换其基类且不破坏程序的正确性。使用多态、面向接口编程。// ❌ 违反里氏替换原则classBird{public:virtualvoidfly(){/* 飞行 */}};classPenguin:publicBird{public:voidfly()override{throwstd::runtime_error(Penguins cant fly!);}};// ✅ 正确的设计classBird{/* 基类不包含fly */};classFlyingBird:publicBird{public:virtualvoidfly()0;};classSparrow:publicFlyingBird{/* 可以飞 */};classPenguin:publicBird{/* 企鹅只是鸟不会飞 */};实际经验子类不应该覆盖父类的非抽象方法子类可以有更严格的前置条件但必须有更宽松的后置条件3.4 接口隔离原则Interface Segregation Principle, ISP定义客户端不应该依赖它不需要的接口。核心思想提供尽可能小的单独接口而不要提供大的总接口。将一个大接口分解为多个小接口。// ❌ 违反接口隔离原则classIWorker{public:virtualvoidwork()0;virtualvoideat()0;};// ✅ 遵循接口隔离原则classIWorkable{public:virtualvoidwork()0;};classIFeedable{public:virtualvoideat()0;};classWorker:publicIWorkable,publicIFeedable{// 实现工作接口voidwork()override{/* ... */}// 实现进食接口voideat()override{/* ... */}};classRobot:publicIWorkable{// 机器人只需要工作不需要进食voidwork()override{/* ... */}};实际经验接口的粒度要适中太大会导致实现类被迫实现不需要的方法太小会导致接口数量爆炸一个接口只服务于一个子模块或业务逻辑3.5 依赖倒置原则Dependency Inversion Principle, DIP定义高层模块不应该依赖低层模块两者都应该依赖其抽象抽象不应该依赖细节细节应该依赖抽象。核心思想面向接口编程。当模块A需要用到模块B的功能时应当通过一个接口来使用B而不是直接使用B的实现。// ❌ 违反依赖倒置原则classMySQLDatabase{public:voidsave(string data){/* MySQL存储 */}};classUserService{MySQLDatabase*db;// 直接依赖具体实现public:voidsaveUser(string data){db-save(data);}};// ✅ 遵循依赖倒置原则classIDatabase{public:virtualvoidsave(string data)0;virtual~IDatabase()default;};classMySQLDatabase:publicIDatabase{public:voidsave(string data)override{/* MySQL存储 */}};classPostgreSQLDatabase:publicIDatabase{public:voidsave(string data)override{/* PostgreSQL存储 */}};classUserService{IDatabase*db;// 依赖抽象接口public:UserService(IDatabase*database):db(database){}voidsaveUser(string data){db-save(data);}};实际经验依赖注入是实现依赖倒置原则的常用手段通过构造函数、setter方法或接口传递依赖四、设计模式与SOLID原则的关系设计模式是SOLID原则的具体应用每种设计模式都体现了某些SOLID原则。设计模式体现的SOLID原则工厂模式依赖倒置原则、开闭原则单例模式单一职责原则策略模式开闭原则、单一职责原则观察者模式开闭原则、依赖倒置原则适配器模式开闭原则、接口隔离原则装饰器模式开闭原则、单一职责原则模板方法模式开闭原则 理解要点设计模式是手段原则是目的设计模式是实现设计原则的具体方法灵活应用不要为了使用设计模式而使用要根据实际需求选择权衡取舍设计模式会增加代码复杂度需要权衡利弊五、学习建议 推荐学习路径第一步理解面向对象基础 → 第二步学习SOLID原则 → 第三步学习设计模式 ↓ 第四步项目实战应用 ↓ 第五步阅读优秀源码 实践建议从小处着手先在小型项目中尝试应用设计模式重构现有代码在代码重构中应用设计模式效果最佳阅读开源项目学习优秀项目如何使用设计模式画UML图用类图辅助理解设计模式的结构写技术博客输出是最好的学习方式⚠️ 常见误区误区正确理解设计模式越多越好根据实际需求选择过度设计反而有害设计生搬硬套理解模式的本质灵活应用忽视简单性简单的代码优于复杂的模式只学用法不学原理理解设计原则才能真正掌握设计模式六、总结设计模式是软件开发的智慧结晶SOLID原则是面向对象设计的指导思想。掌握它们能够 提高代码质量和可维护性 增强代码的可扩展性和灵活性 提升团队协作效率 培养良好的设计思维记住设计模式不是银弹正确的使用场景和方法才是关键。参考资料C各类设计模式及实现详解 - 知乎面向对象5个基本原则 - CSDN突破编程_C_设计模式策略模式- CSDN

相关文章:

设计模式基础与SOLID原则

🏗️ 设计模式基础与SOLID原则 设计模式是软件开发中经过验证的、可复用的解决方案。掌握设计模式,能够让我们的代码更加优雅、可维护、可扩展。 一、什么是设计模式 设计模式(Design Pattern)是一套被反复使用、多数人知晓的、经…...

从 LLM 到 Agent:“工具”和“主动性”?

最近AI概念实在是太火,后端java仔不得不跟上时代。 从大语言模型出现以后,人们发现它可以写论文、写代码、做总结、回答问题,表现得非常强大。但在实际使用中,也逐渐暴露出几个明显问题: 第一,幻觉严重。…...

告别报销烦恼!金蝶AI星辰费用报销实操指南,让企业效率飞起来

还在为繁琐的费用报销流程头疼吗?员工填单慢、财务审核累、老板看不清账?别担心,金蝶AI星辰带着“云报销”功能来拯救你了!今天,我们就用一篇通俗易懂的实操指南,带你体验从“报销难”到“报销爽”的华丽蜕…...

(10个核心知识点解构分章版)深度解析TCP/IP网络协议栈:从基础概念到核心机制的全方位指南

(10个核心知识点解构分章版)深度解析TCP/IP网络协议栈:从基础概念到核心机制的全方位指南作者:培风图南以星河揽胜 发布日期:2026-04-24 标签:#计算机网络 #TCP/IP #面试必备 #网络原理 #CSDN原创前言:为什么我们需要深…...

一条查询跑了 8 小时,改写后 519 毫秒?金仓子查询等价谓词传递优化深度解析

引言:明明有 WHERE 条件,为什么数据库还是全表扫描?你有没有遇到过这样的场景:写了一条 SQL,外层明明带了精确的 WHERE 过滤条件,但执行计划一看——子查询内部仍然是全表扫描,没有利用到任何过…...

为什么WHERE中的函数调用会引发灾难?揭秘KES与Oracle的函数执行顺序之谜

在 WHERE 子句里放一个"有副作用"的函数,就像在高速公路上放了一个随机变道的司机——也许今天没事,但迟早会出事故。引言:一段看起来"理所当然"的代码在一次代码评审中,我看到了这样一条 SQL:SEL…...

深度拆解 HermesAgent(二):闭环学习系统 —— AI Agent 如何“自我进化“?

深度拆解 HermesAgent(二):闭环学习系统 —— AI Agent 如何"自我进化"? 系列导读:本文是 HermesAgent 深度拆解系列 的第二篇。我们将深入分析 HermesAgent 最核心的创新——闭环学习系统,看看 …...

数据结构入门:栈实现全解析

个人专栏:《数据结构-初阶》《经典OJ题目》《C语言》 欢迎各位大佬交流! 目录 一、栈的概念及结构 1、栈的基本概念 2、栈的结构 二、代码实现 0、初始化 1、入栈 2、出栈 3、返回栈顶元素 4、获取栈中有效元素个数 5、检测栈是否为空 6、销毁…...

Sambert多情感语音合成部署教程:一键启动,快速体验AI语音生成

Sambert多情感语音合成部署教程:一键启动,快速体验AI语音生成 1. 引言:为什么选择Sambert语音合成? 在当今数字化时代,语音合成技术已经广泛应用于智能客服、有声读物、虚拟助手等领域。然而,传统语音合成…...

Keras深度学习多分类实战:从数据预处理到模型部署

1. 深度学习多分类实战:基于Keras的完整指南在计算机视觉和自然语言处理领域,多分类问题就像一位超市理货员需要将商品准确归到不同货架——MNIST手写数字识别要把图像分到0-9共10个类别,新闻主题分类则需将文章划入政治、经济或体育等板块。…...

Python Flask工程目录解读

📁 项目根目录 usedCar 项目主目录,是整个工程的工作区。📁 applications — 应用核心 Flask 应用的工厂模式组织目录,包含业务应用的初始化、扩展管理和全局配置。子目录/文件作用config.py应用全局配置文件,包含数据…...

AAEON GENE-EHL5工业级单板计算机解析与应用

1. AAEON GENE-EHL5 3.5英寸单板计算机概述AAEON GENE-EHL5是一款基于Intel Elkhart Lake处理器的3.5英寸单板计算机(SBC),专为工业自动化和边缘计算应用设计。这款紧凑型主板采用了Intel Atom x6000E系列、Pentium和Celeron处理器,在146101.7mm的标准3.…...

RWKV7-1.5B-G1A模型效果展示:对比传统LSTM在文本生成上的优势

RWKV7-1.5B-G1A模型效果展示:对比传统LSTM在文本生成上的优势 1. 开场亮点 最近测试了RWKV7-1.5B-G1A这个新模型,它在文本生成上的表现确实让人眼前一亮。特别是和传统LSTM对比时,差异更加明显。记得去年用LSTM做文本生成时,经常…...

计算机组成原理教学辅助:用LM Z-Image模拟CPU指令执行

计算机组成原理教学辅助:用LM Z-Image模拟CPU指令执行 1. 教学痛点与解决方案 计算机组成原理是计算机专业的核心课程,但学生在学习过程中常常遇到两个主要困难:一是难以将抽象的指令执行过程可视化,二是无法直观理解寄存器、AL…...

医疗AI安全评估框架:原理、实现与最佳实践

1. 医疗AI安全评估框架概述医疗领域的大型语言模型(LLMs)正在快速改变临床决策支持的方式,从急诊医学到精神科,AI助手已经能够提供专家级的诊疗建议。然而,这些系统面临着两类关键安全威胁:对抗攻击&#x…...

LFM2-VL-1.6B软件测试新范式:自动化生成测试用例与报告

LFM2-VL-1.6B软件测试新范式:自动化生成测试用例与报告 1. 软件测试的痛点与机遇 在快速迭代的敏捷开发环境中,测试团队常常面临两大挑战:一是测试用例编写耗时费力,二是需求变更导致测试用例维护成本高。传统的手工编写测试用例…...

提示工程:优化AI交互的核心技术与实践

1. 提示工程入门指南在人工智能交互领域,提示工程(Prompt Engineering)已经成为连接人类意图与AI理解的关键桥梁。就像教孩子解数学题需要清晰的题干描述一样,与AI模型有效沟通同样需要特定的表达技巧。我最初接触GPT-3时&#xf…...

SystemC Export API参数管理机制与硬件仿真实践

1. SystemC Export API参数管理机制解析在硬件仿真和系统级建模领域,SystemC Export API提供了一套完整的参数管理机制,这是构建可配置仿真环境的核心基础设施。作为从业十余年的芯片验证工程师,我经常需要与这些API打交道,特别是…...

DTVM:融合EVM生态与Wasm性能的下一代确定性虚拟机

1. 项目概述:下一代确定性虚拟机DTVM 如果你在区块链开发领域摸爬滚打过几年,尤其是在智能合约和虚拟机执行层有过深度实践,那你一定对性能、确定性和生态兼容性这“三座大山”深有体会。传统的EVM(以太坊虚拟机)以其…...

GLM-4.1V-9B-Base与C语言交互:通过本地API实现轻量级集成

GLM-4.1V-9B-Base与C语言交互:通过本地API实现轻量级集成 1. 为什么要在C项目中集成AI能力? 在嵌入式系统和性能敏感型应用中,C语言仍然是无可争议的王者。但传统AI框架往往依赖Python环境,这在资源受限场景下会带来诸多挑战&am…...

大语言模型幻觉现象解析与应对策略

1. 大语言模型幻觉现象概述当ChatGPT告诉你"根据爱因斯坦的相对论,人类可以在火星上种植香蕉"时,这就是典型的LLM幻觉(Hallucination)现象。作为从业者,我亲历过无数次模型一本正经地胡说八道的场景&#xf…...

边缘AI推理延迟骤降78%!Docker WASM混合部署方案全拆解,含3个生产级YAML模板

更多请点击: https://intelliparadigm.com 第一章:边缘AI推理与Docker WASM融合的范式革命 传统边缘AI部署长期受限于容器镜像体积大、启动延迟高、跨平台兼容性差等瓶颈。Docker 24.0 原生支持 WebAssembly(WASM)运行时&#xf…...

机器学习算法清单构建与应用实践指南

1. 算法清单的价值与挑战在机器学习实践中,我们常常面临这样的困境:面对一个具体业务问题时,如何从数百种算法中快速筛选出最适合的候选方案?我曾参与过一个电商推荐系统项目,团队花了整整两周时间反复讨论算法选型&am…...

Copilot Next 工作流自动化配置到底难在哪?92%开发者卡在第3步——资深架构师逐行调试实录

更多请点击: https://intelliparadigm.com 第一章:Copilot Next 工作流自动化配置的认知重构 传统工作流自动化常将 Copilot 视为代码补全工具,而 Copilot Next 的本质是语义驱动的意图执行引擎——它通过上下文感知的 LLM 编排层&#xff…...

Docker AI Toolkit 2026隐藏模式曝光:仅限docker ai enable --stealth启动的联邦学习协调器(附实测吞吐对比表)

更多请点击: https://intelliparadigm.com 第一章:Docker AI Toolkit 2026隐藏模式的发现与定义 Docker AI Toolkit 2026(简称 DAIT-2026)在正式发布版中未公开启用一项实验性功能——--modestealth,该模式通过动态容…...

【仅开放72小时】MCP 2026边缘部署优化SOP v3.2(含ARM64+RISC-V双平台适配清单)

更多请点击: https://intelliparadigm.com 第一章:MCP 2026边缘部署优化SOP发布说明与时效性约束 MCP 2026边缘部署优化标准操作流程(SOP)已于2024年10月1日正式发布,适用于所有基于ARM64与x86_64架构的边缘网关设备&…...

real-anime-z插画工作流整合:从草图生成→风格强化→尺寸适配一站式完成

real-anime-z插画工作流整合:从草图生成→风格强化→尺寸适配一站式完成 1. 镜像介绍与核心价值 real-anime-z是一款专为二次元插画创作设计的文生图工具,它整合了从草图生成到最终成品的完整工作流。这个镜像特别适合需要快速产出动漫风格作品的创作者…...

DeepSeek V4 重新设计了记忆

大家好,我是苍一,一个干了13年的后端开发,正在探索AI编程,从产品到开发的全生命周期最佳实践,如果您感兴趣,欢迎关注👇,看我如何自我革命。发布概况DeepSeek V4 的 preview 版本近日…...

Qwen3-4B-Thinking镜像免配置价值:规避HuggingFace token认证与网络超时问题

Qwen3-4B-Thinking镜像免配置价值:规避HuggingFace token认证与网络超时问题 1. 模型概述与核心优势 1.1 模型背景与技术特点 Qwen3-4B-Thinking-2507-Gemini-2.5-Flash-Distill是基于通义千问Qwen3-4B官方模型开发的高效推理版本。这个镜像通过精心设计的蒸馏技…...

AI工作流引擎:用DAG编排框架提升AI应用开发效率

1. 项目概述:一个面向AI应用开发的现代工作流工具如果你最近在折腾AI应用开发,无论是想快速搭建一个智能对话机器人,还是想把大语言模型(LLM)的能力集成到你的业务系统里,大概率会遇到一个共同的烦恼&#…...