系分 - UML【概念】

news2025/1/11 11:17:53

在这里插入图片描述

个人总结,仅供参考,欢迎加好友一起讨论

文章目录

  • UML - Unified Modeling Language
    • UML中有4种事物
      • 结构事物
      • 行为事物
      • 分组事物
      • 注释事物
    • UML图的分类
      • 结构型图(静态图)
      • 行为型图(动态图)
    • UML图 - 静态图[结构型]
      • 类图(Class Diagram)
      • 对象图(Object Diagram)
      • 构件图/组件图(Component Diagram)
      • 部署图(Deployment Diagram)
      • 制品图(Arifiet Diagram)
      • 包图(Packet Diagram)
      • 组织结构图(Composite Structure Diagram)
    • UML图 - 动态图[行为型]
      • 用例图(Use Case Diagram)
      • 顺序图(Sequence Diagram)
      • 通信图(Communication Diagram)
      • 定时图(Timing Diagram)
      • 活动图(Activity Diagram)
      • 交互预览图(Interaction Overview Diagram)
      • 状态图(State Diagram)

UML - Unified Modeling Language

Unified Modeling Language(UML)又称统一建模语言或标准建模语言,它是一个支持模型化和软件系统开发的图形化语言,为软件开发的所有阶段提供模型化和可视化支持,包括由需求分析到规格,到构造和配置。

UML中有4种事物

UML中的事物包括结构事物、行为事物(动作事物)、分组事物(组织事物)和注释事物(辅助事物)。这些事物是UML模型中面向对象的基本建筑块,他们在模型中属于静态部分,代表物理上或概念上的元素。

结构事物

结构事物主要包括7种,分别是类、接口、用例、协作、活动类、组件和节点 。

1)类(Class)

类是具有相同属性、相同方法、相同语义和相同关系的一组对象的集合。一个类可以实现一个或多个接口。在UML图中,类用包括类名、属性和方法的矩形来表示。

在这里插入图片描述

2)接口(Interface)

接口是指类或组件提供的、可以完成特定功能的一组操作的集合。换句话说,接口描述了类或组件对外的、可见的动作。通常,一个类实现一个或多个接口。在UML图中,接口通常用一个圆形来表示。

在这里插入图片描述

3)用例(Use Case)

用例定义了系统执行的一组操作,对特定的用户产生可以观察的结果。在UML图中,用例通常用一个实线椭圆来表示。

在这里插入图片描述

4)协作(Collaboration)

协作定义了交互的操作,表示一些角色和其他元素一起工作,提供一些合作的动作。一个给定的类可能是几个协作的组成部分,这些协作代表构成系统的模式的实现。在UML图中,协作通常用一个虚线椭圆表示。

在这里插入图片描述

5)活动类(Active Class)

活动类是指对象有一个或多个线程或进程的类。活动类和类相似,只是它的对象代表的元素的行为和其他的元素同时存在。在UML图中,活动类的表示方法和普通类的表示方法相似,也是使用一个矩形,只是最外面的边框使用粗线。

在这里插入图片描述

6)组件(Component)

组件是物理上可替换的,实现了一个或多个接口的系统元素。在UML图中,组件的表示图形比较复杂。

在这里插入图片描述

7)节点(Node)

节点是一个物理元素,它在运行时存在,代表一个可计算的资源,比如一台数据库服务器。在UML图中,节点使用一个立方体来表示。节点通常包括处理器和设备。

在这里插入图片描述

行为事物

行为事物也称动作事物,是UML模型中的动态部分,代表时间和空间上的动作。行为事物主要有两种:交互和状态机。它们是UML模型中最基本的两个动态事物元素,通常和其他的结构元素、主要的类、对象连接在一起。

1) 交互(Interaction)

交互是在特定上下文中的一组对象,为共同完成一定的任务而进行的一系列消息交换所组成的动作。交互包括消息、动作序列(消息产生的动作)、对象之间的连接。在 UML图中,交互的消息通常画成带箭头的直线。

2) 状态机(State Machine)

状态机是对象的一个或多个状态的集合。在UML图中,状态机通常用一个圆角矩形来表示。

在这里插入图片描述

分组事物

分组事物也成为组织事物,是UML模型中组织的部分,可以把它看做一个个的盒子,每个盒子里面的对象关系相对复杂,而盒子与盒子之间的关系相对简单。组织事物只有一种,包。

包(Package)

包是一种有组织地将一系列元素分组的机制。包与组件最大的区别在于,包纯粹是一种概念上的东西,仅仅窜在于开发阶段结束之前,而组件是一种物理元素,存在于运行时。在UML图中,包通常表示为一个类似文件夹的符号。

在这里插入图片描述

注释事物

注释事物也称辅助事物,属于这一类的只有注释。

注释(Annotation)

注释就是UML模型的解释部分。在UML图中一般表示为折起一角的矩形。

在这里插入图片描述

UML图的分类

UML图分为结构型的图和行为型的图。

结构型图(静态图)

结构型的图(Structure Diagram)也称作静态图,包括:类图(Class Diagram)、对象图(Object Diagram)、构件图(Component Diagram)、部署图(Deployment Diagram)、制品图(Arifiet Diagram)、包图(Packet Diagram)、组织结构图(Composite Structure Diagram)。

行为型图(动态图)

行为型的图(Behavior Diagram)也称作动态图,包括:用例图(Use Case Diagram)、顺序图(Sequence Diagram)、通信图(Communication Diagram)、定时图(Timing Diagram)、交互预览图(Interaction Overview Diagram)、活动图(Activity Diagram)、状态图(State Diagram)。

其中,顺序图、通信图、定时图、交互概览图,被称为交互图。速记口诀:交通定顺。

UML图 - 静态图[结构型]

类图(Class Diagram)

类图是一切面向对象方法的核心建模工具,它描述了系统中对象的类型以及它们之间存在的各种静态关系。

类图是用来表示类、接口以及它们之间的静态结构和关系。

在类图中,常见的有以下几种关系:

依赖(Dependency)

依赖关系是一种使用关系,即一个类的实现需要另一个类的协助,也就是use-a的关系。

在UML中,依赖关系用带普通箭头的虚线表示,由依赖的一方指向被依赖的一方。

在这里插入图片描述

如上,司机只管开车,车是谁的不重要,给什么车开什么车。

泛化(Generalization)

泛化关系是一种继承关系,表示子类继承父类的所有特征和行为,也就是is-a的关系。子类继承自父类,父类是子类的泛化。父类又称作基类或超类,子类又称作派生类。

在UML中,泛化关系用带空心三角箭头的实线来表示,箭头指向父类。

在这里插入图片描述

实现(Realization)

实现关系是一种类与接口的关系,表示类是接口所有特征和行为的实现。在这种关系中,类实现了接口,类中的操作实现了接口中所声明的操作。

在UML中,类与接口之间的实现关系用带空心三角形箭头的虚线来表示,箭头指向接口。

在这里插入图片描述

关联(Association)

关联关系是一种拥有关系,它使得一个类知道另一个类的属性和方法,成员变量的形式。如:老师与学生,丈夫与妻子。关联是类之间的结构关系,它描述了一组链,链是对象之间的连接。两个类之间可以有多个由不同角色标识的关联。关联可以是双向的,也可以是单向的。

在UML中,用带普通箭头的实线,指向被拥有者。双向的关联可以有两个箭头,或者没有箭头。单向的关联有一个箭头。

在这里插入图片描述

如上,自己买的车,想什么时候开就开。但是车是车,人是人,没有整体与部分的关系。

聚合(Aggregation)

聚合关系是一种整体与部分的关系,且部分可以离开整体而单独存在,即has-a的关系。聚合关系是关联关系的一种,是强的关联关系;关联和聚合在语法上无法区分,必须考察具体的逻辑关系。

在UML中,聚合关系用带空心菱形的实线表示,空心菱形指向整体。例如:汽车发动机(Engine)是汽车(Car)的组成部分,但是汽车发动机可以独立存在,因此,汽车和发动机是聚合关系。

在这里插入图片描述

如上,电脑有键盘才能输入信息,电脑是整体,键盘是部分,键盘也可以离开电脑,单纯的拿去敲。所以是聚合。

组合(Composition)

组合关系是一种整体与部分的关系,但部分不能离开整体而单独存在,即contains-a的关系。组合关系是关联关系的一种,是比聚合关系还要强的关系。

在UML中,组合关系用带实心菱形的实线表示,实心菱形指向整体。

在这里插入图片描述

如上,鸟是整体,翅膀是部分。鸟死了,翅膀也就不能飞了。所以是组合。

我们再看一下,下面的一组经典的聚合组合关系的例子。如下:

在这里插入图片描述

如上,一个公司拥有多个部门,公司和部门之间是组合关系,公司破产了,部门就不复存在了。部门和员工是聚合关系,部门被裁掉,员工还能活,换下家呗。

对象图(Object Diagram)

对象图是类图的一个实例,是系统在某个时间点的详细状态的快照。

对象图用来表示两个或者多个对象之间在某一时刻之间的关系。

在这里插入图片描述

如上,就是描述的,某时间点bat这个公司有一个研发部,一个销售部,两个部门只有一个人iisheng

构件图/组件图(Component Diagram)

构件图也被称为组件图,其描绘了系统中构件/组件提供的、需要的接口、端口等,以及它们之间的关系,其目的是用来展示各个组件之间的依赖关系。使用构件图的思想是复用。就像是我们盖房子,当房子的大体框架建好之后,剩下的门和窗户家具之类的直接拿来安装上即可,不需要再从新制作,直接拿来复用的思想。这些门和窗户就相当于一个个的构件。

在这里插入图片描述

如上,订单系统组件依赖于客户资源库和库存系统组件。中间的虚线箭头表示依赖关系。另外两个符号,表示组件连接器,一个提供接口,一个需要接口。

部署图(Deployment Diagram)

部署图描述了系统内部的软件如何分布在不同的节点上,用来表示软件和硬件的映射关系。从部署图中,可以了解到软件和硬件组件之间的物理关系以及处理节点的组件分布情况。使用部署图可以显示运行时系统的结构,同时还传达构成应用程序的硬件和软件元素的配置和部署方式。

在这里插入图片描述

如上,图中简单的表示了不同机器上面部署的不同软件。

制品图(Arifiet Diagram)

制品图描述计算机中一个系统的物理结构。制品包括文件、数据库和类似的物理比特集合。制品图通常与部署图一起使用,制品也给出了它们实现的类和构件。

包图(Packet Diagram)

包图描绘了系统在包层面上的结构设计,用来表示包和包之间的依赖关系。包图可以描述需求,设计的高阶概况;包图通过合理规划自身功能反应系统的高层架构,在逻辑上将系统进行模块化分解;包图最终是组织源码的方式。

在UML中用类似于文件夹的符号表示的模型元素的组合。包图是一种维护和描述系统总体结构的模型的重要建模工具,通过对包中各个包以及包之间关系的描述,展现出系统的模块与模块之间的依赖关系。

包图经常被描述成文件夹,可以用于UML任何一种的图上。包图只是把某些类放在一个包中,因此可以看做是类图的一种。

在这里插入图片描述

如上:

  • 《Use》关系表示使用依赖,Web Shopping依赖Payment
  • 《Merge》关系表示合并,Web Shopping合并了Shopping Cart就拥有了Shopping Cart的功能
  • 《Access》关系表示私有引入,比如代码中的指定包名类名
  • 《Import》关系表示公共引入,比如Java中的import之后,就可以直接使用import包中的类了。

组织结构图(Composite Structure Diagram)

组织结构图,也被称为复合结构图。描述了一个"组合结构"的内部结构,以及他们之间的关系。这个"组合结构"可以是系统的一部分,或者一个整体。其目的是用来表示系统中逻辑上的"组合结构"。

在这里插入图片描述

如上,图中描述了Car是由车轴连接着的两个前面轮子、两个后面轮子,和引擎组合的。

UML图 - 动态图[行为型]

用例图(Use Case Diagram)

用例图是指由参与者、用例,边界以及它们之间的关系构成的用于描述系统功能的视图。其目的是用来描述整个系统的功能,

用例图(User Case)是外部用户(被称为参与者)所能观察到的系统功能的模型图。用例图是系统的蓝图,用于需求分析阶段。用例图呈现了一些参与者,一些用例,以及它们之间的关系,主要用于对系统、子系统或类的功能行为进行建模。

在这里插入图片描述

如上,用例图中包含以下三种关系:

  • 包含关系使用符号《include》,箭头从基用例指向子用例。想要查看订单列表,前提是需要先登录。
  • 扩展关系使用符号《extend》,箭头从子用例指向基用例。基于查询订单列表的功能,可以增加一个导出数据的功能。
  • 泛化关系,子用例继承父用例所有结构、行为和关系。

顺序图(Sequence Diagram)

顺序图,在UML1.x的时候也被称为序列图。顺序图根据时间顺序(序列)展示对象如何进行协作,强调消息时间顺序的交互。它展示了在用例的特定场景中,对象如何与其他对象交互。其目的是通过描述对象之间发送消息的时间顺序显示多个对象之间的动态协作。

顺序图,它由一组对象或参与者以及它们之间可能发送的消息构成。构成顺序图的基本元素包括对象、生命线和消息,还可以包括角色和激活期两种元素。

在这里插入图片描述

如上,图中展示的是支付宝条码支付场景的序列图。其中,loop是循环,alt是选择。

通信图(Communication Diagram)

在UML1.x的时候通信图也被称为协作图。描述了收发消息的对象的组织关系,强调对象之间的合作关系而不是时间顺序。通信图强调接收和发送信息的对象的结构组织的交互,强调参加交互的对象的组织,用来显示不同对象的关系。

在这里插入图片描述

如上,图中展示了一个线上书店的通信图,方框和小人表示生命线,不同生命线之间可以传递消息,消息前面的数字可以表达序列顺序。

定时图(Timing Diagram)

定时图也被称作计时图,它适合嵌入式系统建模的交互图。定时图是一种新增的、特别适合实时和嵌入式系统建模的交互图。关注沿着线性时间轴、生命线内部和生命线之间的条件改变。描述对象状态随着时间改变的情况,很像示波器,适合分析周期和非周期性任务。定时图强调消息跨域不同对象或参与者的实际时间,而不仅仅关心消息的相对顺序。被用来显示随时间变化,一个或多个元素的值或状态的更改。也显示时控事件之间的交互和管理它们的时间和期限约束。用来表示元素状态或者值随时间的变化而变化的视图。

定时图采用一种带数字刻度的时间轴来精确地描述消息的顺序,而不是像顺序图那样只是指定消息的相对顺序,而且它还允许可视化地表示每条生命线的状态变化,当需要对实时事件进行建模时,定时图可以很好地满足要求。

定时图的焦点集中于生命线内部以及它们之间沿着时间轴的条件变化。

定时图可以把状态发生变化的时刻以及各个状态所持续的时间具体地表示出来。如果把多个对象放在一个定时图中,还可以把它们之间发送和接收消息的时刻表示出来。在这方面,定时图与其他几种交互图相比具有独到的优势。

定时图来自于电子工程领域,在需要明确定时约束一些事件时可以使用它们。

在这里插入图片描述

如上,图中展示了老年痴呆病人随着时间的变化病情的变化。

活动图(Activity Diagram)

将进程或其他计算的结构展示为计算内部一步步的控制流和数据流,主要用来描述具体业务用例的实现流程。活动图在本质上是一种流程图。活动图着重表现从一个活动到另一个活动的控制流,是内部处理驱动的流程。活动图主要描述行为的动作,表示用例实现的工作流程。

泳道在UML活动图中区分了负责活动的对象,它明确地表示了哪些活动是由哪些对象进行的。

在这里插入图片描述

如上,图中简单描述了,从开始到登录到查看订单列表,或者登录失败直接结束。

交互预览图(Interaction Overview Diagram)

交互概览图与活动图类似,但是它的节点是交互图,用来提供了控制流的概述。

交互概览图强调控制流的交互图。交互概览图是活动图和顺序图的混合物。活动图的变体,描述业务过程中的控制流概览,软件过程中的详细逻辑概览,以及将多个图进行连接,抽象掉了消息和生命线。

在这里插入图片描述

如上,图中表示一个调度系统的交互概览图,跟活动图很像。其中sd的框代表具体的交互流程,ref框代表使用交互。

状态图(State Diagram)

状态图也可以被叫做状态机图,状态图对一个单独对象的行为建模,指明对象在它的整个生命周期里,响应不同事件时,执行相关事件的顺序。用来描述一个特定的对象所有可能的状态,以及由于各种事件的发生而引起的状态之间的转移和变化。在整个生命周期,响应不同事件的不同状态。状态图主要描述行为的结果。

在这里插入图片描述

如上,图中描述了,门在其生命周期内所经历的状态。

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

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

相关文章

C#枚举器和迭代器

C#枚举器和迭代器 使用foreach语句时,可以依次取出数组里面的元素,原因就是数组提供了“枚举器(Enumerator)”,枚举器知道元素的位置并返回请求项。 枚举器IEnumerator 枚举器实现了IEnumerator接口,该接…

Angular页面使用指令和路由守卫进行权限控制

在各种业务系统中,为了保证业务及数据安全,除了要求用户必须登录后才能操作外,还针对不同的角色对不同用户设置了各自的访问权限,包括确定的某个页面的权限和页面中特定元素的权限。本文记录了一种Angular页面常用的权限管理方法。…

C++:std::function模板类

一:function定义 类模板 std::function是一种通用的多态函数包装器,它的实例可以对任何可以调用的目标实体进行存储,复制和调用操作。简单的来说:C中有几种可调用对象:函数,指针,lambda表达式&…

区块链之开发命令行操作模块

文章目录功能介绍go语言中flag用法简介项目命令行具体实现链接: 区块链项目github地址项目目前进度:功能介绍 利用命令行操作区块链相较于图形用户界面来说,编写代码简单,同时也可以实现复杂的功能。命令行模块的功能应该满足&am…

Java学习笔记 --- JDBC(1)

一、JDBC概述 基本介绍 1、JDBC为访问不同的数据库提供了统一的接口,为使用者屏蔽了细节问题 2、Java程序员使用JDBC可以连接任何提供了JDBC驱动程序的数据库系统,从而完成对数据库的各种操作 3、JDBC原理图 JDBC带来的好处 JDBC是Java提供一套用于数…

安卓移动端调用自然语言处理nlp模型【示例+源码】

安卓可以使用许多不同的方法来调用NLP模型。其中一种方法是使用现有的自然语言处理库,例如 Apache OpenNLP、 Stanford NLP 和 NLTK。这些库提供了许多常用的 NLP 功能,如分词、词干化、命名实体识别和词性标注。另一种方法是使用 TensorFlow Lite 或其他机器学习框架来加载并…

[ins 2022] 针对已见和未见群体的群体推荐中的贝叶斯归纳学习

Bayesian inductive learning in group recommendations for seen and unseen groupshttps://www.sciencedirect.com/science/article/pii/S0020025522008933摘要群组推荐是指向一组用户(即成员)推荐物品。在预测相关项目时,模型通常会面临未…

fs 文件系统模块

1、什么是 fs 文件系统模块 fs 模块是 Node.js 官方提供的、用来操作文件的模块。它提供了一系列的方法和属性,用来满足用户对文件的操作需求。 方法名 说明 fs.readFile() 用来读取指定文件中的内容 fs.writeFile() 用来向指定的文件中写入内容 如果要在 J…

webflux整合swagger教程V2版

1. yml文件配置 <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId><version>2.1.0.RELEASE</version></dependency><!--数据库开始--&…

python @classmethod

1..什么是classmethod classmethod是用来指定一个类的方法为类方法 长的像下面这个样子 1 2 3 class cc: classmethod def f(cls, arg1, arg2, ...): ... cls通常用作类方法的第一参数 跟self有点类似&#xff08; __init__里面的slef通常用作实例方法的第一参数)。…

vue开发环境配置Visual Studio Code配置和安装教程

方便前端vue开发&#xff0c;使用vs code插件安装详细教程&#xff0c;关于vs code可以网络上相关的教程&#xff0c;插件安装如下图所示&#xff0c;大家常用的插件可再分享&#xff0c;与我联系。 1 安装Vue语法高亮显示插件&#xff1a;vetur 2 安装vue语法提示插件&#xf…

小孩上了半年小学,针对老师的评语总结,如何对症优化教育培养策略?chatGPT搜了一下,AI震惊了我

评语 班主任评语&#xff1a; 你是一个性格内向、聪明伶俐的男孩。平时能按时完成老师布置的作业&#xff0c;学习认真&#xff0c;成绩优良&#xff0c;做事认真。但有时自己的事情还不能自己完成&#xff0c;希望你以后可以独立起来&#xff0c;遇到问题多想办法&…

高性能网关基石——OpenResty

什么是 OpenRestyOpenResty 一个基于 Nginx 的高性能 Web 平台&#xff0c;能够方便地搭建处理超高并发的动态 Web 应用、 Web 服务和动态网关。例如有名的 Kong 网关和国产新秀 ApiSIX 网关都是基于 OpenResty 来进行打造的。OpenResty 通过实现 ngx_lua 和 stream_lua 等 Ngi…

Nmap工具使用

Nmap工具使用1.Nmap简介1.1.Nmap介绍1.2.Nmap功能介绍1.3.Nmap下载1.4.Nmap端口状态2.Nmap基本使用2.1.Nmap基础扫描2.2.Nmap基础扫描多个目标2.3.Nmap详细扫描输出2.4.Nmap指定端口扫描2.4.1.单端口扫描2.4.2.端口范围扫描2.4.3.端口组合扫描2.5.Nmap扫描排除2.5.1.排除一个主…

强大的ANTLR4(6)--设计语法

四种抽象的计算机语言模式&#xff1a; 1&#xff09;序列&#xff1a;一列元素&#xff0c;数组 2&#xff09;选择&#xff1a;在多个可选方案中做出选择 3&#xff09;词法符号依赖&#xff1a;例如左右括号匹配 4&#xff09;嵌套结构&#xff1a;一种自相似的语言结构。 …

lambda表达式入门

一、函数式编程思想 1 概念 面向对象思想需要关注用什么对象完成什么时期&#xff0c;而函数式编程思想更类似于我们数学中的函数&#xff0c;它主要关注的是对数据进行了什么操作 2 优点 代码简洁&#xff0c;开发快速接近自然语言&#xff0c;易于理解易于"并发编程…

计算机网络——BGP协议

BGP协议 和谁交换&#xff1a;与其他AS的邻站BGP发言人交换信息。 交换什么&#xff1a;交换网络可达性信息 多久交换一次&#xff1a;发生变化时更新有变化的部分 一般来说两个网络都是由一个BGP发言人连接的。 BGP协议交换信息的过程 BGP协议所交换的网络可达性的信息就…

Haproxy 代理后端服务

参考 http://www.haproxy.org HAProxy GitHub 目录 一、Haproxy环境准备 1、Haproxy简介 1.1、haproxy原理 1.2、Haproxy优点 2、在线apt安装 二、使用Haproxy 1、基本脚本结构示例 2、配置反向代理 3、验证haproxy 3.1、重启服务 3.2、访问后台管理 3.3、访问…

Linux下用gdb定位Qt程序崩溃位置(systemd-coredump)

目录1. systemd-coredump2. 用gdb定位崩溃位置Linux提供了systemd-coredump服务&#xff0c;可以配合gdb来定位到程序崩溃位置&#xff0c;下面介绍它们的用法。1. systemd-coredump systemd-coredump的简单介绍&#xff1a; systemd-coredump能从操作系统内核中获取内存转储&…

IDEA2022.1创建Maven web项目 + SpringMVC入门学习

SpingMVC 入门案例 文章目录SpingMVC 入门案例项目的结构1.导入SpringMVC和Servlet依赖2.创建SpringMVC控制器类&#xff08;等同Servlet&#xff09;3.初始化SpingMVC环境&#xff08;同Spring环境&#xff09;&#xff0c;设定SpringMVC加载对应的bean4.创建web容器启动类&am…