UML总结----六种关系和九种图的作用

简介: UML总结----六种关系和九种图的作用

已经学习了UML,应该对UML有一个大概的认识,下面一张图是我画的一个思维导图。


eb4a1bbf37281310f05e6d4fc7927c39_watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NTMwOTE1NQ==,size_16,color_FFFFFF,t_70.png


从图上可以看出UML可以大致分为视图、事物、关系以及它的9种图。


视图


在逻辑视图中:逻辑视图通常由类图、对象图以及包图表示,组件图通常由组件图表示,并发图通常由状态图、活动图、时序图、协作图表示,配置图通常由配置图表示,用例图通常由用例图表示。


结构事物也分为了类、接口、用例、协作、活动类、组件和节点


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


接口:接口是指类或组件所提供的、可以完成特定功能的一组操作的集合。即:接口描述了类或组件的对外的、可见动作,通常一个类实现一个或多个接口。


用例:用例定义了系统的一组操作,对特定的用户产生可以观察的结果。


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


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


组件:组件是物理上可替换的,实现了一个或多个皆苦的系统元素。


节点:节点是一个物理元素,它在运行时存在,代表一个可计算的资源,在UML中,节点使用一个立方体来表示。


关系

关联关系:关联关系是一种结构化关系,指一种对象和另一种对象有关联。是一种拥有关系,使一个类知道另一个类的属性和方法,如:老师与学生、丈夫与妻子。关联关系可以有方向,表示该关联在某方向被使用。只在一个方向上存在的关联,称为单向关联,在两个方向是国内都存在的叫做双向关联。关联关系用一条实线表示。双向关联可以有两个或没有箭头,单向关联有一个箭头。


e29a9d1afdb46b5714181ade4b82998f_20200705084541695.png

3d97daab8819cb6fdde7a8157f646c4a_20200705091416565.png


老师和学生是双向关联,老师可以有多名学生,学生也可以有多名老师,但学生与课程之间是单向关联,一名学生可以有多门课程,课程不拥有学生。


聚合:是关联的特例,聚合表示类与类之间关系时整体与部分的关系。聚合是整体与部分的关系,部分可以离开整体而单独存在,如果在聚集关系中储运部分方的对象可同时参与多个处于整体方对象的构成,则该聚集称为共享聚合。 在IUML中聚合关系用一段带有空心小菱形的直线表示,菱形端连接表示整体事物的模型元素,另一端连接的是部分事物的模型元素。


例如:一个评委可以参加多个比赛,表示歌唱大赛由评委等对象组成


045e6ac3647ecd3d12320773e7b3bf38_20200705085445922.png


组合关系:组合关系时再聚合关系之上的更紧密的耦合关系,描述元素之间部分与整体的关系。部分类需要整体类才能存在,当整体类背销毁,部分类将同时被销毁。组合关系用一端带有实心小菱形的直线表示,菱形端连接表示整体事物的模型元素,另一端连接表示部分事物的模型元素。


d30d15bc88c5bc96eedc3bdee0e7bc70_20200705091858742.png


依赖:依赖关系描述两个模型元素(类、用例)之间的语义关系,是一种使用关系。其中一个模型元素是独立的,另一个模型元素不是独立的,它依赖于独立的模型元素,如果独立的模型元素改变,将影响依赖于它的元素。箭头指向为被指用者。


d2026deaafabe1afa14d77a4badc94ab_20200705092253495.png


泛化:是一种继承关系,表示一般与特殊的关系,指定了子类如何特化父类的所有特征和行为。泛化可分为普通泛化以及受限泛化。普通泛化就是没有给泛化添加约束。普通泛化关系用一条带有空心箭头的实线表示,箭头指向父类。受限泛化可以给泛化关系附加约束条件,说明该泛化关系的使用方法或扩充方法。


426ae81e7d6cbc229dc936f17099857a_20200705092959119.png


实现:是一种类与接口的关系,表示类是接口的所有特征和行为的实现。再UML中用带三角的虚线表示,箭头指向接口。


3bfbd3befae441ff69d5cb2cca9a7ae7_20200705093500970.png


各种关系强弱顺序:泛化=实现>组合>聚合>关联>依赖


下图描述了各类的关系:


918bb95ea9982b0a603bdcc052d1c1db_watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NTMwOTE1NQ==,size_16,color_FFFFFF,t_70.png


另外:用例图分为用例图;静态图分为:类图、对象图、包图;交互图:时序图、协作图


在需求阶段:采用用例图描述需求


分析阶段:用类图描述静态结构


设计阶段:采用类图、包图对类的接口进行设计


实现阶段:将类用某个面向对象的语言实现


集成交付阶段:构件图、包图、部署图


测试阶段:单元测试用类图和类的规格说明书,集成测试阶段用类图、包图、构件图和合作图,系统测试阶段用用例图来测试系统功能。


用例图:描述角色以及角色与用例直接按的连接关系。说明谁要使用系统,以及他们使用该系统可以做什么


类图:描述系统的静态结构,以及各个类之间的关系的静态视图。


对象图:描述系统在某个时刻的静态静态结构。它是类图的实例,对象图i西安市类的多个对象实例,而不是实例的类。


活动图:描述用例要求所要进行的活动,以及活动间的约束关系。


状态图:描述类的对象所有可能的状态,以及事件发生时状态的转移条件。


序列图:按事件顺序描述系统元素间的交互,用来显示你的参与者如何以一系列顺序的步骤与系统的对象交互的模型。


协作图:显示对象间的活动合作状态,可以看成时类图和顺序图的交集,按时间、空间顺序描述系统元素间的交互,和他们之间的关系。


构件图(组件图):描述代码构件的物理结构以及各种构建直接按的额依赖关系。实现系统的元素的组织。


部署图:用来建模系统的物理部署。例如计算机和设备,以及他们之间是如何连接的,部署的使用者是开发人员。系统集成人员和测试人员。



以上是对UML的总结,如有不足指出,欢迎指正!


https://blog.csdn.net/dragonpeng2008/article/details/6836448


相关文章
|
8月前
|
存储 测试技术 开发工具
软考中的UML图、数据流图等二十余种示例
软考中的UML图、数据流图等二十余种示例
659 0
|
7月前
|
设计模式 uml
设计模式学习心得之前置知识 UML图看法与六大原则(下)
设计模式学习心得之前置知识 UML图看法与六大原则(下)
49 2
|
7月前
|
设计模式 数据可视化 程序员
设计模式学习心得之前置知识 UML图看法与六大原则(上)
设计模式学习心得之前置知识 UML图看法与六大原则(上)
51 0
|
7月前
|
数据可视化 测试技术 uml
如果更好的绘制UML图
如果更好的绘制UML图
51 0
|
8月前
|
Java uml
UML之组件图(构件图)
UML之组件图(构件图)
222 0
|
8月前
|
程序员 uml
UML图 | 时序图(顺序、序列图)绘制
UML图 | 时序图(顺序、序列图)绘制
878 0
|
8月前
|
测试技术 uml
UML—浅谈常用九种图
UML—浅谈常用九种图
261 0
|
设计模式 数据可视化 程序员
设计模式概述、UML图、软件设计原则
设计模式概述 软件设计模式的产生背景 "设计模式"最初并不是出现在软件设计中,而是被用于建筑领域的设计中。 1977年美国著名建筑大师、加利福尼亚大学伯克利分校环境结构中心主任克里斯托夫·亚历山大(Christopher Alexander)在他的著作《建筑模式语言:城镇、建筑、构造》中描述了一些常见的建筑设计问题,并提出了 253 种关于对城镇、邻里、住宅、花园和房间等进行设计的基本模式。 1990年软件工程界开始研讨设计模式的话题,后来召开了多次关于设计模式的研讨会。直到1995 年,艾瑞克·伽马(ErichGamma)、理査德·海尔姆(Richard Helm)、拉尔夫·约翰森(Ra
80 0
|
数据可视化 测试技术 uml
UML概述及UML图详解
UML概述及UML图详解
341 0
UML概述及UML图详解
|
uml C++
UML——实现图(组件图、部署图)
在进行完前面的系统逻辑设计之后,下一步我们就需要定义设计的物理实现,如可执行文件、库、表、文件和文档等。UML的实现图又分为了:组件图和部署图两部分