UML之泛化、特化和继承

在UML(统一建模语言)中,泛化(Generalization)和特化(Specialization)是面向对象思想中继承(Inheritance)关系的重要概念,它们描述类与类(或用例与用例、参与者与参与者等)之间的一般与特殊的关系。

泛化是一种表示类之间继承关系的方式,它指定了子类如何特化超类(父类)的所有特征和行为。在UML中,泛化关系通过带空心三角箭头的实线表示,箭头指向超类。这种关系表明,子类是一种特殊的超类,它继承了超类的所有属性、操作(方法)以及与其他类的关系,并且可能添加新的属性、操作或改变超类某些行为的具体实现。泛化关系支持代码重用和多态,是实现软件设计复用性和灵活性的重要手段。

特化是泛化的逆过程,即从一般到特殊的过程。虽然UML中更常用“泛化”来描述这种关系,但“特化”一词在面向对象编程和UML的语境下,也常被用来描述子类如何成为超类的一个特定版本或实现。特化意味着子类不仅继承了超类的所有属性和操作,还可能对这些属性和操作进行特定的实现或限制,以满足特定的需求。特化是面向对象编程中实现多态性和代码复用的基础之一。

简而言之,泛化和特化是同一继承关系的两个不同视角:泛化沿空心三角箭头向上移动,它从父类的角度描述子类如何成为其特殊化版本,而特化则沿空心三角箭头向下移动,它从子类的角度描述其如何特化或具体化父类的属性和行为。这两个概念在UML中用于清晰地表示类之间的继承关系,促进软件设计的复用性和可维护性。

当然,泛化和特化这种继承关系不只可以用于描述类的关系,也可以应用于用例、参与者等UML元素。

下图使用继承关系描述了UML中不同图之间的关系。

在上图中,对其顶层关系可以做出如下解读:

  • 结构图(Structure Diagram)是一种图(Diagram)。
  • 结构图(Structure Diagram)是图(Diagram)的一种(或某类图)。
  • 结构图(Structure Diagram)是图(Diagram)的一种特化。
  • 图(Diagram)是结构图(Structure Diagram)的泛化。
  • 结构图(Structure Diagram)和行为图(Behavior Diagram)是图(Diagram)的子类型。
  • 图(Diagram)是结构图(Structure Diagram)和行为图(Behavior Diagram)的父类型。

特化关系允许子类替代超类,为了实现替代,超类上所有可用的特性(属性、操作、约束、信号、接收和关联)也必须在子类上可用。

在UML图中描述这种继承关系时,可以让所有子类在超类侧共享一个空心三角形,令其整体呈树状结构。当然,也完全可以让每个子类在超类侧使用自己独有的空心三角形。并且空心三角的位置只要是指向并紧贴对应的超类即可,其与超类的接触点及方向可以是任意的,我们可以基于布局需要和美观因素进行选择与调整。

下图展示了继承关系中的一些细节,通过阅读这张图我们可以了解继承是如何进行工作的。

注:在UML中如果类名是斜体,如图中的“Borrowable Material”则表示该类是一个抽象类。

超类“可借阅材料(Borrowable Material)”的特性,包含属性编号(number)、标题(title)及操作借阅(borrow()),被所有子类继承,即它们在所有子类上都是可用的。

子类“音频CD(Audio CD)”和“书籍(Book)”的类图描述中,上述属性编号(number)、标题(title)被重复描述了。UML建议使用插入符号(^)标记继承的特性,子类“音频CD(Audio CD)”遵循这个规则在属性number和title前添加了“^”符号表明这两个属性是继承自超类。但并非所有UML工具都遵循了这一建议,例如Enterprise Architect,它将属性列表按所属类进行分段,源自超类的属性它将使用“::超类名”进行命名空间标注,正如图中子类“书籍(Book)”那样,超类的属性number和title被展示在了“::Borrowable Material”之下的区域;而Visual Paradigm则在表示时不区分该特性是继承自超类还是当前类所特有的。

实际上,在描绘UML图形时,并不需要描画所有继承自超类的特性,例如上图中在超类“可借阅材料(Borrowable Material)”中的操作借阅borrow()在两个子类(Audio CD和Book)中均未展示,但子类确实会继承借阅borrow()这个操作。

在子类Audio CD中我们添加了另外一个新的属性ISRC,在子类Book中我们也添加了新的属性ISBN。这使得这两个子类均拥有三个属性,其中两个继承自它们的超类Borrowable Material,另外一个是这两个子类所特有的属性。

类Juvenile Book和类Adult Book均继承自类Book。它们又各自添加了一条自己特有属性,而继承自超类的属性类Juvenile Book采用了在属性前添加插入符号(^)的形式进行说明,此时,只能通过这个符号表明属性是继承自超类,而具体是继承自类Book还是Borrowable Material并没有办法进行区分;类Adult Book在表示属性时由于采用了命名空间的方式,它则可以明确地表明继承的属性来自哪个超类。

对于类Book,在图中还通过关联的方式与类Person建立关系,在关联的末端的“+author”表明在类Book中还有一个多重性为任意、有序的、类型为Person、名为author的属性;类似的,类Peron也有一个多重性为任意、类型为Book的名为myBook的属性。

对于类Book的子类Juvenile Book与Adult Book,上述类Book与类Person的关联关系也会由于存在继承关系而自动拥有。不过需要特别注意的是,子类Juvenile Book与Adult Book从关联中会继承角色名称author(作为属性author),而myBook是存在于类Person中的角色名称,它并不会产生任何继承关系。子类Juvenile Book采用在属性区域描画的方式展示了它继承于关联的角色名称author;而子类Adult Book则通过添加与类Person关联的方式展示它继承于关联的角色名称author,并且,它更改了它在类Person中的对应的角色名称(属性名称)。

当在一个子类中请求一个特性时,它会检索该特性的定义。如果在当前子类中找不到该特性的定义,它就会检索该子类的直接超类(父类),如果依然没有找到,则继续向上层超类检索,直到找到最近的该特性的定义为止。如果检索到超类链的顶端也未找到该特性的定义,UML规范并未说明这会发生什么,通常这是实现或者说编程语言层面的问题。

注:在具体的编程语言中,可能会面临更加复杂情况,例如在一个子类中定义与超类完全相同的属性与操作,而在实例化时,又通过超类类型的变量名指向一个子类的实例。此时,通过这个变量访问属性与操作将变得更加难以理解。

通过继承关系与其他关系结合,可以精确描述更为复杂的场景。例如继承关系与组合关系一起使用,可以描述复杂结构的构成。例如一个系统中包含有两种类型的结构:简单结构和复合结构。简单结构是单一结构,而复合结构由多个结构构成,这些结构既可以是简单结构也可以是复合结构。基于此,我们可以用下图来描述这个结构的关系。

在图中简单结构(Simple Structure)和复合结构(Compound Structure)这两者均继承于不能实例化的(抽象)结构(Structure);抽象结构与复合结构之间存在组合关系,一个复合结构可能包含有任意多个结构,而这个结构要么是简单结构要么是复合结构。

泛化、特化和继承 – 光头颜说ITicon-default.png?t=O83Ahttps://gtyan.com/archives/367

UML之图框架标题类型之谬-CSDN博客

UML之类与类图-CSDN博客

UML之修饰符-CSDN博客

UML之类型-CSDN博客

UML之包与包图-CSDN博客

UML之包的导入与访问-CSDN博客

UML之模型、包及包的版型(构造型)_包体系结构-CSDN博客

UML之属性与参数的多重性_uml类图中,关于多重性的表示-CSDN博客

UML之集合类型-CSDN博客

UML之关联-CSDN博客

UML之组合与聚合-CSDN博客

UML规约2.5.1下载icon-default.png?t=O83Ahttps://download.csdn.net/download/mboy2008/90211443

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

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

相关文章

【时时三省】(C语言基础)常见的动态内存错误2

山不在高,有仙则名。水不在深,有龙则灵。 ----CSDN 时时三省 对非动态开辟空间内存使用free释放 示例: 这个arr数组是在栈上的 *p指向的就是arr 对非动态空间也用了free ferr只能在动态开辟空间使用 使用free释放一块动态开辟空间的一部分…

leecode718.最长重复子数组

二维空间版 class Solution { public:int findLength(vector<int>& nums1, vector<int>& nums2) {int mnums1.size(),nnums2.size();vector<vector<int>> dp(m,vector<int>(n));int result0;for(int i0;i<m;i)if(nums1[i]nums2[0]){…

「Mac畅玩鸿蒙与硬件54」UI互动应用篇31 - 滑动解锁屏幕功能

本篇教程将实现滑动解锁屏幕功能&#xff0c;通过 Slider 组件实现滑动操作&#xff0c;学习事件监听、状态更新和交互逻辑的实现方法。 关键词 滑动解锁UI交互状态管理动态更新事件监听 一、功能说明 滑动解锁屏幕功能包含以下功能&#xff1a; 滑动解锁区域&#xff1a;用…

电子应用设计方案86:智能 AI背景墙系统设计

智能 AI 背景墙系统设计 一、引言 智能 AI 背景墙系统旨在为用户创造一个动态、个性化且具有交互性的空间装饰体验&#xff0c;通过融合先进的技术和创意设计&#xff0c;提升室内环境的美观度和功能性。 二、系统概述 1. 系统目标 - 提供多种主题和风格的背景墙显示效果&…

基于物联网疫苗冷链物流监测系统设计

1. 项目开发背景 随着全球对疫苗运输要求的提高&#xff0c;特别是针对温度敏感型药品&#xff08;如疫苗&#xff09;的冷链管理&#xff0c;如何保证疫苗在运输过程中的温度、湿度、震动等环境因素的稳定性已成为亟需解决的问题。疫苗运输过程中&#xff0c;任何温度或湿度的…

Trimble天宝X9三维扫描仪为建筑外墙检测提供了全新的解决方案【沪敖3D】

随着城市化进程的快速推进&#xff0c;城市高层建筑不断增多&#xff0c;对建筑质量的要求也在不断提高。建筑外墙检测&#xff0c;如平整度和垂直度检测&#xff0c;是衡量建筑质量的重要指标之一。传统人工检测方法不仅操作繁琐、效率低下&#xff0c;还难以全面反映墙体的真…

瑞吉外卖项目学习笔记(十)修改套餐、删除套餐、起售和停售套餐

瑞吉外卖项目学习笔记(一)准备工作、员工登录功能实现 瑞吉外卖项目学习笔记(二)Swagger、logback、表单校验和参数打印功能的实现 瑞吉外卖项目学习笔记(三)过滤器实现登录校验、添加员工、分页查询员工信息 瑞吉外卖项目学习笔记(四)TableField(fill FieldFill.INSERT)公共字…

Python 实时获取Linux服务器信息

在进行服务器监控、运维管理时&#xff0c;实时获取服务器信息至关重要。特别是在 Linux 环境下&#xff0c;我们常常需要获取系统的运行状态、资源占用情况以及硬件信息。如果你是运维人员、开发者或是正在做自动化运维任务的人&#xff0c;那么如何高效地实时获取 Linux 服务…

MATLAB程序转C# WPF,dll集成,混合编程

工作中遇到一个需求&#xff0c;有一部分算法的代码需要MATLAB来进行处理&#xff0c;而最后需要集成到C#中的wpf项目中去&#xff0c;选择灵活性更高的dll&#xff0c;去进行集成。&#xff08;可以简单理解为&#xff1a;将MATLAB的函数&#xff0c;变为C#中类的函数成员&…

「Mac畅玩鸿蒙与硬件49」UI互动应用篇26 - 数字填色游戏

本篇教程将带你实现一个数字填色小游戏&#xff0c;通过简单的交互逻辑&#xff0c;学习如何使用鸿蒙开发组件创建趣味性强的应用。 关键词 UI互动应用数字填色动态交互逻辑判断游戏开发 一、功能说明 数字填色小游戏包含以下功能&#xff1a; 数字选择&#xff1a;用户点击…

深入理解 pytest Fixture 方法及其应用

在 Python 自动化测试领域&#xff0c;pytest 是当之无愧的王者。提到 pytest&#xff0c;不得不说它的一大核心功能——Fixture。Fixture 的强大&#xff0c;让复杂的测试流程变得井井有条&#xff0c;让测试代码更加灵活和可复用。 那么&#xff0c;pytest 的 Fixture 究竟是…

【AI编辑器】Cursor与DeepSeek模型的集成:提升开发效率的新选择

目录 一、为什么选择DeepSeek模型 1.1 模型参数与训练 1.2 技术创新 1、FP8格式介绍 2、FP8混合精度训练的优势 3、FP8混合精度训练的技术要点 4、FP8混合精度训练的应用与挑战 1.3 性能表现 1.4 应用与部署 1.5 争议与前景 二、注册DeepSeek账号并获取API Key 三、…

什么情况会导致JVM退出?

大家好&#xff0c;我是锋哥。今天分享关于【什么情况会导致JVM退出?】面试题。希望对大家有帮助&#xff1b; 什么情况会导致JVM退出? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 JVM&#xff08;Java Virtual Machine&#xff09;在不同情况下可能会退出&am…

软件工程实验-实验2 结构化分析与设计-总体设计和数据库设计

一、实验内容 1. 绘制工资支付系统的功能结构图和数据库 在系统设计阶段&#xff0c;要设计软件体系结构&#xff0c;即是确定软件系统中每个程序是由哪些模块组成的&#xff0c;以及这些模块相互间的关系。同时把模块组织成良好的层次系统&#xff1a;顶层模块通过调用它的下层…

《Rust权威指南》学习笔记(三)

泛型和trait 1.泛型可以提高代码的复用能力&#xff0c;泛型是具体类型或其他属性的抽象代替&#xff0c;可以看成是一种模版&#xff0c;一个占位符&#xff0c;编译器在编译时会将这些占位符替换成具体的类型&#xff0c;这个过程叫做“单态化”&#xff0c;所以使用泛型的…

计算机网络基础(7)中科大郑铨老师笔记

应用层 目标&#xff1a;  网络应用的 原理&#xff1a;网络应用协议的概念和实现方面 传输层的服务模型 客户-服务器模式 对等模式(peerto-peer) 内容分发网络  网络应用的 实例&#xff1a;互联网流行的应用层协 议  HTTP  FTP  SMTP / POP3 / IMAP  DNS…

2022浙江大学信号与系统笔记

原视频地址&#xff1a;2022浙江大学信号与系统&#xff08;含配套课件和代码&#xff09; - 胡浩基老师-哔哩哔哩 ⭐⭐⭐ 我的笔记&#xff1a;飞书链接 - 信号与系统 基于视频&#xff0c;记得笔记&#xff0c;加了点自己的补充&#xff08;有的是问 ChatGPT 的&#xff09;…

数学建模入门——建模流程

摘要&#xff1a;本文介绍了数学建模的一般流程概述。 目录 一、前言 二、数据预处理 三、描述性统计分析 四、模型建立 五、模型评价 一、前言 本文将为想要入门数学建模的同学讲述数学建模的一般流程。但数学建模流程并非一成不变。虽有大致步骤&#xff0c;像分析问题、…

如何使用OpenCV进行抓图-多线程

前言 需求&#xff1a; 1、如何使用OpenCV捕抓Windows电脑上USB摄像头的流、 2、采用多线程 3、获知当前摄像头的帧率。 这个需求&#xff0c;之前就有做了&#xff0c;但是由于出现了一个问题&#xff0c;人家摄像头的帧率目前都可以达到60帧/s 了&#xff0c;而我的程序…

NLP CH3复习

CH3 3.1 几种损失函数 3.2 激活函数性质 3.3 哪几种激活函数会发生梯度消失 3.4 为什么会梯度消失 3.5 如何解决梯度消失和过拟合 3.6 梯度下降的区别 3.6.1 梯度下降&#xff08;GD&#xff09; 全批量&#xff1a;在每次迭代中使用全部数据来计算损失函数的梯度。计算成本…