本篇,来继续介绍UML中的另一种图——时序图。
时序图(Sequence Diagram),也叫顺序图,或序列图,是一种UML动态图。
UML具有许多不同类型的图表,包括:
时序图通过描述对象之间发送消息的时间顺序显示多个对象之间的交互模式。
时序图将交互关系表示为一个二维图
参与者,或称为系统角色,以一个小人图标表示。
对象,以一个矩形表示,在一个系统中可以有多个对象。
生命线就是一条垂直的虚线。
激活,也叫会话,或控制焦点,代表时序图中对象执行一项操作的时期, 表示该对象被占用以完成某个任务,以一个垂直的窄的矩形表示。
以一条实线和实心箭头表示。
消息的发送者把控制传递给消息的接收者,然后停止活动,等待消息的接收者放弃或者返回控制。用来表示同步的意义。
以小于号和虚线表示。
返回消息表示从过程调用返回。
以一条实线和大于号表示。
消息发送者通过消息把信号传递给消息的接收者,然后继续自己的活动,不等待接受者返回消息或者控制。异步消息的接收者和发送者是并发工作的。
以一个半闭合的长方形+下方实心剪头表示。
表示方法的自身调用或者一个对象内的一个方法调用另外一个方法。
选择片段,或称条件分支,可根据不同的条件,执行不同的交互,类似于if-else语句
表明该片段会被重复执行,类似于while或for语句
片段的功能,除了上面介绍的选择、循环和并向、还有许多其它类型,这里详细列举一下,作为参考:
片段类型 | 名称 | 说明 |
---|---|---|
Alt | 选择 | 在一组行为中根据特定的条件选择某个交互 |
Loop | 循环 | 交互片段会被重复执行 |
Par | 并行 | 支持交互片段的并发执行 |
Opt | 选项 | 表示一个可选的行为 |
Break | 中断 | 提供了和编程语言中的break类拟的机制 |
Seq | 弱顺序 | 有两个或更多操作数片段,如果消息涉及的生命线不同,会并行交错 |
Strict | 强顺序 | 有两个或更多操作数片段,这些片段必须按给定顺序发生 |
默认情况下,序列图表明可能发生的一系列消息。在运行的系统中,可能会出现您未选择显示在关系图上的其他消息。
以下片段类型可用于更改此释义:
片段类型 | 名称 | 说明 |
---|---|---|
Consider | 考虑 | 明确标志了应该被处理的消息 |
Assert | 断言 | 标志了在交互片段中作为事件唯一的合法继续者的操作数 |
Neg | 否定 | 用来标志不应该发生的交互 |
Ignore | 忽略 | 明确定义了交互片段不应该响应的消息 |
新建一个visio文件,打开后会自动提示选择创建某种类型的图,这里选择"软件和数据库 ->UML序列"
点击确定之后,会进入UML时序图的编辑界面,左侧可以看到用于UML时序图编辑的基本元素,将这些元素拖拽到右侧的编解面板中,可以看到这些元素的基本结构形式:
注意visio中的生命线绘图元素,实际上包含了参加者元素或对象元素,所以命名为了参与者生命线和对象生命线
下面通过一个实例来介绍一下UML时序图的画法。
这是一个嵌入式开发中,常见的对物联网设备进行配网的操作流程,配网的方式有很多,具体可看之前的文章:【图解】物联网设备的N种Wi-Fi配网方式,这个时序图是其中的一种配网方式——设备热点配网。
解读一下此时序图:
本时序图中,暂未体现出片段的用法,以后有能用到片段用法的例子再举例分析。
在用Visio绘制UML时序图,使用“交互操作数”时,可能遇到宽度被锁定不能调节的问题,解决方法如下:
步骤一:文件----选项----高级----常规-----勾选“以开发人员模式运行”
步骤二:菜单栏出现“开发工具”选项,点击受保护框图,取消宽度的保护
本篇介绍了UML时序图的基础知识,并通过visio绘制一个物联网设备WIFI配网的UML时序图实例,来介绍UML时序图的画法与所表达的含义。