理解设计模式与 UML 类图:构建稳健软件架构的基石

在软件开发的广阔天地里,设计模式与 UML(统一建模语言)类图犹如两座灯塔,为开发者照亮前行的道路,指引着我们构建出高质量、可维护且易于扩展的软件系统。今天,就让我们一同深入探索单一职责、开闭原则、简单工厂模式以及 UML 类图中的关键概念,包括关联、依赖、泛化、实现,还有关联关系中的特殊形式 —— 组合与聚合。

一、设计模式的基石:单一职责与开闭原则

(一)单一职责原则

单一职责原则如同软件世界中的 “专注大师”,它强调一个类只应承担一个职责,即仅有一个引起它变化的原因。想象一下,如果一个类既负责数据的存储,又负责数据的展示与用户交互,那么一旦用户界面需要调整,数据存储部分可能也会受到牵连,导致代码的稳定性和可维护性大打折扣。例如,在一个电商系统中,我们有一个 Product 类,它的职责应该仅仅是处理与产品相关的信息,如产品名称、价格、库存等,而不应该涉及订单处理或用户账户管理等其他功能。这样,当产品的属性或业务逻辑发生变化时,我们只需要关注 Product 类本身,而不用担心对其他无关模块造成影响。

(二)开闭原则

开闭原则则像是一位 “包容的智者”,倡导软件实体对扩展开放,对修改关闭。这意味着当系统需要添加新功能或适应新的需求变化时,我们应该通过扩展现有代码来实现,而不是直接修改已有的稳定代码。以一个图形绘制系统为例,最初系统可能只支持绘制圆形和矩形。按照开闭原则,我们可以设计一个抽象的 Shape 类,Circle 和 Rectangle 类继承自它。当需要添加绘制三角形的功能时,我们只需创建一个新的 Triangle 类继承自 Shape 类,而无需修改 ShapeCircle 和 Rectangle 类中的原有代码。这样,既保证了系统的稳定性,又能灵活地应对不断变化的需求。

二、简单工厂模式:对象创建的智慧工厂

简单工厂模式犹如一个高效的 “生产车间”,负责创建对象而将对象的使用与创建过程分离开来。在实际应用中,比如在一个游戏开发场景里,有多种角色类型,如战士、法师、刺客等。我们可以创建一个 CharacterFactory 简单工厂类,它根据传入的参数(如角色类型的标识)来决定创建哪种具体的角色对象。这样,游戏中的其他模块,如游戏场景、战斗逻辑等,只需要从这个工厂获取角色对象,而不必关心角色是如何被创建出来的。这大大降低了代码的耦合度,使得各个模块可以独立地进行开发、测试和维护。

三、UML 类图:软件架构的蓝图

UML 类图是软件架构的可视化蓝图,它通过各种图形符号和关系来描述系统中的类、对象以及它们之间的交互。其中,关联、依赖、泛化和实现是 UML 类图中几个核心的关系概念。

(一)关联关系

关联关系描绘了类与类之间的一种语义连接,就像是人与人之间的各种联系。在学校管理系统中,Student 类和 Class 类之间存在关联关系,一个班级可以容纳多个学生,而一个学生也必然属于某个班级。在 UML 类图中,关联关系用一条直线表示。这种关系体现了类之间相对稳定的结构联系,是构建复杂系统结构的基础。

(二)依赖关系

依赖关系则更像是一种临时性的 “借力” 行为。例如,Driver 类和 Car 类之间存在依赖关系,因为司机需要驾驶汽车才能完成运输任务。在代码层面,可能是 Driver 类的某个方法中使用了 Car 类的对象。在 UML 类图中,依赖关系用带箭头的虚线表示,箭头指向被依赖的类。依赖关系表明一个类的变化可能会影响到另一个类,但这种影响相对较弱且局部。

(三)泛化关系

泛化关系就是我们熟知的继承关系,它体现了一种 “is-a” 的层次结构。以动物世界为例,Mammal(哺乳动物)类是一个泛化的概念,Cat(猫)类和 Dog(狗)类都继承自 Mammal 类,它们共享 Mammal 类的一些共性特征,如具有毛发、哺育后代等,同时又各自具有独特的属性和行为。在 UML 类图中,泛化关系用带空心三角形箭头的实线表示,箭头指向父类。泛化关系有助于代码的复用和扩展,通过继承父类的属性和方法,子类可以减少重复代码的编写,并且可以根据自身需求进行个性化的扩展。

(四)实现关系

实现关系主要用于接口和实现类之间的桥梁搭建。比如,在一个图形绘制库中,有一个 Shape 接口,它定义了图形绘制的基本方法,如 draw 方法。而 Circle 类、Rectangle 类等具体的图形类则实现了这个 Shape 接口,它们必须按照接口的规范来实现 draw 方法。在 UML 类图中,实现关系用带空心三角形箭头的虚线表示,箭头指向接口。实现关系使得不同的类可以遵循相同的接口规范,从而提高了代码的灵活性和可替换性。

四、关联关系中的特殊形式:组合与聚合

(一)聚合关系

聚合关系是一种相对松散的整体与部分关系,就像汽车和轮胎的关系。轮胎是汽车的一部分,但轮胎可以从汽车上拆卸下来,单独存在并可能被安装到其他汽车上。在 UML 类图中,聚合关系用空心菱形箭头的直线表示,箭头指向整体。聚合关系体现了一种弱的 “拥有” 关系,部分的生命周期可以独立于整体。

(二)组合关系

组合关系则是一种紧密的整体与部分关系,类似于人体和心脏的关系。心脏是人体不可或缺的一部分,当人体不存在时,心脏也就失去了其存在的意义,其生命周期完全依赖于整体。在 UML 类图中,组合关系用实心菱形箭头的直线表示,箭头指向整体。组合关系强调了部分与整体的强关联性和不可分割性。

理解并熟练运用这些设计模式和 UML 类图的概念,对于软件开发者来说具有极其重要的意义。它们能够帮助我们在软件开发的初期就设计出合理的架构,提高代码的质量和可维护性,减少后期因需求变更而带来的巨大成本。无论是初入编程世界的新手,还是经验丰富的资深开发者,深入研究这些知识都将为我们的软件开发之旅带来无尽的智慧和力量。让我们在实践中不断探索和应用这些宝贵的理念,构建出更加优秀的软件系统。

以上就是关于单一职责、开闭原则、简单工厂模式以及 UML 类图相关概念的深入探讨,希望能为广大开发者在软件架构设计和开发过程中提供有益的参考和启示。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/61569.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

业务架构、数据架构、应用架构和技术架构

TOGAF(The Open Group Architecture Framework)是一个广泛应用的企业架构框架,旨在帮助组织高效地进行架构设计和管理。 TOGAF 的核心就是由我们熟知的四大架构领域组成:业务架构、数据架构、应用架构和技术架构。 企业数字化架构设计中的最常见要素是4A 架构。 4…

苹果Siri将搭载大型语言模型,近屿智能抢占AIGC大模型人才培养高地

据媒体报道,苹果公司正在研发一款全新升级、更加智能且对话能力显著提升的Siri,意在超越OpenAI的ChatGPT及其他语音服务。 报道指出,新一代Siri将搭载更为先进的大型语言模型(LLM),苹果期望其能够进行连续…

【1.4 Getting Started--->Support Matrix】

主页:支持矩阵 这些支持矩阵概述了 TensorRT API、解析器和层支持的平台、特性和硬件功能。 Support Matrix Abstract 这些支持矩阵概述了 TensorRT API、解析器和层所支持的平台、功能和硬件功能。 有关之前发布的 TensorRT 文档,请参阅 TensorRT 档…

WPF中如何让Textbox显示为一条直线

由于Textbox直接使用是一条直线 设置如下代码 可以让Textbox变为直线输入 <Style TargetType"TextBox"x:Key"UsernameTextBoxStyle"><Setter Property"Template"><Setter.Value><ControlTemplate TargetType"{x:Typ…

Mac 修改默认jdk版本

当前会话生效 这里演示将 Java 17 版本降低到 Java 8 查看已安装的 Java 版本&#xff1a; 在终端&#xff08;Terminal&#xff09;中运行以下命令&#xff0c;查看已安装的 Java 版本列表 /usr/libexec/java_home -V设置默认 Java 版本&#xff1a; 找到 Java 8 的安装路…

K8S + Jenkins 做CICD

前言 这里会做整体CICD的思路和流程的介绍&#xff0c;会给出核心的Jenkins pipeline脚本&#xff0c;最后会演示一下 实验/实操 结果 由于整体内容较多&#xff0c;所以不打算在这里做每一步的详细演示 - 本文仅作自己的实操记录和日后回顾用 要看保姆式教学的可以划走了&…

使用 前端技术 创建 QR 码生成器 API1

前言 QR码&#xff08;Quick Response Code&#xff09;是一种二维码&#xff0c;于1994年开发。它能快速存储和识别数据&#xff0c;包含黑白方块图案&#xff0c;常用于扫描获取信息。QR码具有高容错性和快速读取的优点&#xff0c;广泛应用于广告、支付、物流等领域。通过扫…

基于Java Springboot高校工作室管理系统

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术&#xff1a;Html、Css、Js、Vue、Element-ui 数据库&#xff1a;MySQL 后端技术&#xff1a;Java、Spring Boot、MyBatis 三、运行环境 开发工具&#xff1a;IDEA/eclipse 数据…

【读书】复杂性意义结构框架——Cynefin框架

Cynefin框架 《代码大全》的作者史蒂夫麦克康奈尔&#xff08;Steve McConnell&#xff09;在《卓有成效的敏捷》这本书里&#xff0c;探讨了用于理解不确定性和复杂性的Cynefin框架。 Cynefin框架是戴维斯诺登&#xff08;David Snowden&#xff09;20世纪90年代的在IBM时创…

ZYNQ-7020嵌入式系统学习笔记(1)——使用ARM核配置UART发送Helloworld

本工程实现调用ZYNQ-7000的内部ARM处理器&#xff0c;通过UART给电脑发送字符串。 硬件&#xff1a;正点原子领航者-7020 开发平台&#xff1a;Vivado 2018、 SDK 1 Vivado部分操作 1.1 新建工程 设置工程名&#xff0c;选择芯片型号。 1.2 添加和配置PS IP 点击IP INTEGR…

全面击破工程级复杂缓存难题

目录 一、走进业务中的缓存 &#xff08;一&#xff09;本地缓存 &#xff08;二&#xff09;分布式缓存 二、缓存更新模式分析 &#xff08;一&#xff09;Cache Aside Pattern&#xff08;旁路缓存模式&#xff09; 读操作流程 写操作流程 流程问题思考 问题1&#…

SpringSecurity创建一个简单的自定义表单的认证应用

1、SpringSecurity 自定义表单 在 Spring Security 中创建自定义表单认证应用是一个常见的需求&#xff0c;特别是在需要自定义登录页面、认证逻辑或添加额外的表单字段时。以下是一个详细的步骤指南&#xff0c;帮助你创建一个自定义表单认证应用。 2、基于 SpringSecurity 的…

用python简单集成一个分词工具

本部分记录如何利用Python进行分词工具集成&#xff0c;集成工具可以实现运行无环境要求&#xff0c;同时也更方便。 该文章主要是记录&#xff0c;知识点不是特别多&#xff0c;欢迎访问个人博客&#xff1a;https://blog.jiumoz.top/archives/fen-ci-gong-ju-ji-cheng 成品展…

Fakelocation Server服务器/专业版 Windows11

前言:需要Windows11系统 Fakelocation开源文件系统需求 Windows11 | Fakelocation | 任务一 打开 PowerShell&#xff08;以管理员身份&#xff09;命令安装 Chocolatey Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProto…

【云计算】腾讯云架构高级工程师认证TCP--考纲例题,知识点总结

【云计算】腾讯云架构高级工程师认证TCCP–知识点总结&#xff0c;排版整理 文章目录 1、云计算架构概论1.1 五大版块知识点&#xff08;架构设计&#xff0c;基础服务&#xff0c;高阶技术&#xff0c;安全&#xff0c;上云&#xff09;1.2 课程详细目录1.3 云基础架构设计1.4…

HarmonyOs鸿蒙开发实战(22)=>开源插件集成-城市选择案例(带字母索引可修改源码)

1.第一步>DevEco Studio集成开源插件 1.1.下载资源插件 1.2.打开Perferences页面&#xff0c;从本地导入安装插件 2.第二步>导入HarmonyOs Next组件市场的城市选择案例&#xff0c;安装 2.1. 代码空白处右键&#xff0c;打开开源组件弹窗 2.2. 安装城市选择案例 3.第三步…

ROS之什么是Node节点和Package包?

1.什么是ROS&#xff1f; 官方术语&#xff1a;ROS&#xff08;Robot Operating System&#xff0c;机器人操作系统&#xff09;是一个开源的、模块化的机器人软件框架。它为机器人开发提供了一套工具和库&#xff0c;用于实现硬件抽象、设备驱动、消息传递、多线程管理等功能…

Windows环境安装MongoDB

文章目录 1. 下载MongoDB2. 安装MongoDB3. Compass-图形化界面客户端4. 更换Compass的主题 阅读本文前可以先阅读以下文章&#xff1a; MongoDB快速入门&#xff08;MongoDB简介、MongoDB的应用场景、MongoDB中的基本概念、MongoDB的数据类型、MongoDB的安装与部署、MongoDB的常…

在线解析工具链接

在线字数统计工具-统计字符字节汉字数字标点符号-计算word文章字数字数统计,字符统计,字节统计,字数计算,统计字数,统计字节数,统计字符数,统计word字数,在线字数统计,在线查字数,计算字数,字数统计工具,支持手机移动端查询多少字数,英文:Calculate the number of words,Count …

RTL8211F 1000M以太网PHY指示灯

在RK3562 Linux5.10 SDK里面已支持该芯片kernel-5.10/drivers/net/phy/realtek.c&#xff0c;而默认是没有去修改到LED配置的&#xff0c;我们根据硬件设计修改相应的寄存器配置&#xff0c;该PHY有3个LED引脚&#xff0c;我们LED0不使用&#xff0c;LED1接绿灯&#xff08;数据…