UML图
概述
构成
-
事物(Things):UML模型中最基本的构成元素,是具有代表性的成分的抽象
-
接口:描述元素的外部可见行为,即服务集合的定义说明
-
用例:代表一个系统或系统的一部分行为,是一组动作序列的集合
-
节点:运行时存在的物理元素
- 另外,参与者、信号应用、文档库、页表等都是上述基本事物的变体
- 行为事物:UML模型图的动态部分,描述跨越空间和时间的行为
- 交互:实现某功能的一组构件事物之间的消息的集合,涉及消息、动作序列、链接
- 状态机:描述事物或交互在生命周期内响应事件所经历的状态序列
-
分组事物: UML模型图的组织部分,描述事物的组织结构
- 包:把元素组织成组的机制
- 注释事物: UML模型的解释部分,用来对模型中的元素进行说明,解释
-
关系(Relationships):关系把事物紧密联系在一起
- 依赖:依赖(dependency)是两个事物之间的语义关系,其中一个事物(独立事物)发生变化,会影响到另一个事物(依赖事物)的语义。
- 关联:关联(association)是一种结构关系,它指明一个事物的对象与另一个事物的对象间的联系。
- 泛化:泛化(generalization)是一种特殊/一般的关系。也可以看作是常说的继承关系。
- 实现:实现(realization)是类元之间的语义关系,其中的一个类元指定了由另一个类元保证执行的契约。
-
图(Diagrams ):图是事物和关系的可视化表示
语法描述:
一.用例图
概要
- 用例图是被称为参与者的外部用户所能观察到的系统功能的模型图。 (《UML参考手册》)
- 用例图列出系统中的用例和系统外的参与者,并显示哪个参与者参与了哪个用例的执行(或称为发起了哪个用例)。
- 用例图多用于静态建模阶段(主要是业务建模和需求建模)
事物及解释
-
参与者(Actor)
- 解释:在系统外部与系统直接交互的人或事物(如另一个计算机系统或一些可运行的进程)。我们需要注意的是:
1.参与者是角色(role)而不是具体的人,它代表了参与者在与系统打交道的过程中所扮演的角色。所以在系统的实际运作中,一个实际用户可能对应系统的多个参与者。不同的用户也可以只对应于一个参与者,从而代表同一参与者的不同实例。
2.参与者作为外部用户(而不是内部)与系统发生交互作用,是它的主要特征。
3.在后面的顺序图等中出现的“参与者”,与此概念相同,但具体指代的含义,视具体情况而定。
-
用例(Use Case)
- 系统外部可见的一个系统功能单元。系统的功能由系统单元所提供,并通过一系列系统单元与一个或多个参与者之间交换的消息所表达 。
用例图中的关系及解释
-
参与者与用例之间的关系
-
关联
- 表示参与者与用例之间的交互,通信途径。
(关联有时候也用带箭头的实线来表示,这样的表示能够显示地表明发起用例的是参与者。)
-
用例之间的关系
-
包含
- 箭头指向的用例为被包含的用例,称为包含用例;箭头出发的用例为基用例。包含用例是必选的,如果缺少包含用例,基用例就不完整;包含用例必须被执行,不需要满足某种条件;其执行并不会改变基用例的行为。
-
扩展
- 箭头指向的用例为被扩展的用例,称为扩展用例;箭头出发的用例为基用例。扩展用例是可选的,如果缺少扩展用例,不会影响到基用例的完整性;扩展用例在一定条件下才会执行,并且其执行会改变基用例的行为。
-
参与者之间的关系
-
泛化
- 发出箭头的事物“is a”箭头指向的事物。泛化关系是一般和特殊关系,发出箭头的一方代表特殊的一方,箭头指向的一方代表一般一方。特殊一方继承了一般方的特性并增加了新的特性。
二.类图
概要
- 类图以反映类的结构(属性、操作)以及类之间的关系为主要目的,描述了软件系统的结构,是一种静态建模方法
- 类图中的“类”与面向对象语言中的“类”的概念是对应的,是对现实世界中的事物的抽象
类图中的事物及解释
-
类
- 从上到下分为三部分,分别是类名、属性和操作。类名是必须有的
- 类如果有属性,则每一个属性都必须有一个名字,另外还可以有其它的描述信息,如可见性、数据类型、缺省值等
- 类如果有操作,则每一个操作也都有一个名字,其它可选的信息包括可见性、参数的名字、参数类型、参数缺省值和操作的返回值的类型等
-
接口
-
抽象类
-
模版类
- 一种参数化的类,在编译时把模版参数绑定到不同的数据类型,从而产生不同的类
类图中的关系及解释
-
关联关系
- 描述了类的结构之间的关系。具有方向、名字、角色和多重性等信息。一般的关联关系语义较弱。也有两种语义较强,分别是聚合与组合
- 聚合关系 :特殊关联关系,指明一个聚集(整体)和组成部分之间的关系
- 组合关系:语义更强的聚合,部分和整体具有相同的生命周期
-
泛化关系
- 在面向对象中一般称为继承关系,存在于父类与子类、父接口与子接口之间
-
实现关系
-
依赖关系
- 描述了一个类的变化对依赖于它的类产生影响的情况。有多种表现形式,例如绑定(bind)、友元(friend)等
三.顺序图
概要
- 顺序图用来表示用例中的行为顺序。当执行一个用例行为时,顺序图中的每条消息对应了一个类操作或状态机中引起转换的事件。
- 顺序图展示对象之间的交互,这些交互是指在场景或用例的事件流中发生的。 顺序图属于动态建模。
- 顺序图的重点在消息序列上,也就是说,描述消息是如何在对象间发送和接收的。表示了对象之间传送消息的时间顺序。
- 浏览顺序图的方法是:从上到下查看对象间交换的消息。
顺序图中的事物及解释
-
参与者
- 与系统、子系统或类发生交互作用的外部用户(参见用例图定义)。
-
对象
- 顺序图的横轴上是与序列有关的对象。对象的表示方法是:矩形框中写有对象或类名,且名字下面有下划线。
-
生命线
- 坐标轴纵向的虚线表示对象在序列中的执行情况(即发送和接收的消息,对象的活动)这条虚线称为对象的“生命线”。
-
消息符号
- 消息用从一个对象的生命线到另一个对象生命线的箭头表示。箭头以时间顺序在图中从上到下排列。
四.协作图
概要
- 协作图是一种交互图,强调的是发送和接收消息的对象之间的组织结构,使用协作图来说明系统的动态情况。
协作图中的事物及解释
-
参与者
- 发出主动操作的对象,负责发送初始消息,启动一个操作。
-
对象
- 对象是类的实例,负责发送和接收消息,与顺序图中的符号相同,冒号前为对象名,冒号后为类名。
-
消息流(由箭头和标签组成)
- 箭头指示消息的流向,从消息的发出者指向接收者。标签对消息作说明,其中,顺序号指出消息的发生顺序,并且指明了消息的嵌套关系;冒号后面是消息的名字。
协作图中的关系及解释
-
链接
- 用线条来表示链接,链接表示两个对象共享一个消息,位于对象之间或参与者与对象之间
消息标签
协作图与顺序图的区别和联系
- 协作图和顺序图都表示出了对象间的交互作用,但是它们侧重点不同。
- 顺序图清楚地表示了交互作用中的时间顺序(强调时间),但没有明确表示对象间的关系。
- 协作图清楚地表示了对象间的关系(强调空间),但时间顺序必须从顺序号获得。
- 协作图和顺序图可以相互转化。
五.状态图
概要
- 状态图:说明对象在它的生命期中响应事件所经历的状态序列,以及它们对那些事件的响应
- 用于揭示Actor、类、子系统和组件的复杂特性。 为实时系统建模
组成
- 状态:对象的状态是指在这个对象的生命期中的一个条件或状况,在此期间对象将
满足某些条件、执行某些活动,或等待某些事件。 - 转移:转移是由一种状态到另一种状态的迁移。这种转移由被建模实体内部或外部事件触发。
对一个类来说,转移通常是调用了一个可以引起状态发生重要变化的操作的结果。
状态图中的事物及解释
-
状态
- 上格放置名称,下格说明处于该状态时,系统或对象要做的工作(见可选活动表)
-
转移
- 转移上标出触发转移的事件表达式。如果转移上未标明事件,则表示在源状态的内部活动执行完毕后自动触发转移
-
开始
-
结束
状态的可选活动表
-
入口动作
-
出口动作
-
外部转换
- 引起状态转换或自身转换,同时执行一个具体的动作,包括引起入口动作和出口动作被执行的转换
-
内部转换
- 引起一个动作的执行但不引起状态的改变或不引起入口动作或出口动作的执行
六.活动图
概要
- 描述系统的动态行为。
- 包含活动状态(ActionState),活动状态是指业务用例的一个执行步骤或一个操作,不是普通对象的状态。
- 活动图适合描述在没有外部事件触发的情况下的系统内部的逻辑执行过程;否则,状态图更容易描述
- 类似于传统意义上的流程图。
- 活动图主要用于:
业务建模时,用于详述业务用例,描述一项业务的执行过程;
设计时,描述操作的流程。
事物
-
活动 (ActionState)
-
起点 (InitialState)
-
终点(FinalState)
-
对象流(ObjectFlowState)
-
发送信号(signalSending)
-
接收信号(SignalReceipt)
-
泳道(SwimLane)
关系
-
迁移(transition)
-
分支(junction point)
-
分叉(fork)
-
结合(join)
七.构件图
概要
- 构件图用于静态建模,是表示构件类型的组织以及各种构件之间依赖关系的图。
- 构件图通过对构件间依赖关系的描述来估计对系统构件的修改给系统可能带来的影响。
构件图中的事物及解释
-
构件
- 指系统中可替换的物理部分,构件名字(如图中的Dictionary)标在矩形中,提供了一组接口的实现。
-
接口
-
构件实例
- 节点实例上的构件的一个实例,冒号后是该构件实例的名字
构件图中的关系及解释
八.部署图
概要
- 部署图用于静态建模,是表示运行时过程节点结构、构件实例及其对象结构的图。
如果含有依赖关系的构件实例放置在不同节点上,部署视图可以展示出执行过程中的瓶颈。
部署图的两种表现形式:实例层部署图和描述层部署图(会在后面的实例中给出)。
部署图中的事物及解释
-
节点
- 节点用一长方体表示,长方体中左上角的文字是节点的名字
节点代表一个至少有存储空间和执行能力的计算资源。
节点包括计算设备和(至少商业模型中的)人力资源或者机械处理资源,可以用描述符或实例代表。
节点定义了运行时对象和构件实例(如图中的Planner构件实例)驻留的位置。
-
构件
-
接口
-
构件实例
部署图中的关系及解释
部署图与构件图
-
部署图与构件图相同的构成元素:
- 构件、接口、构件实例、构件向外提供服务、构件要求外部提供的服务。
-
部署图与构件图的关系:
- 部署图表现构件实例;
构件图表现构件类型的定义。 - 部署图偏向于描述构件在节点中运行时的状态,描述了构件运行的环境;
构件图偏向于描述构件之间相互依赖支持的基本关系。
**
完整版思维导图
**
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)