UML之顺序图_uml顺序图-程序员宅基地

技术标签: 经验分享  uml  软件工程&UML  软件工程  

一:定义

        类图和对象图表达的是系统的静态结构。在一个运行的系统中,对象之间要发生交互,并且这些交互要经历一定的时间。UML顺序图所表达的正是这种基于时间的动态交互。

  • 顺序图用来表示用例中的行为顺序。当执行一个用例行为时,顺序图中的每条消息对应了一个类操作或状态机中引起转换的事件。
  • 顺序图展示对象之间的交互,这些交互是指在场景或用例的事件流中发生的。 顺序图属于动态建模。
  • ​顺序图的重点在消息序列上,也就是说,描述消息是如何在对象间发送和接收的。表示了对象之间传送消息的时间顺序。
  • 浏览顺序图的方法是:从上到下查看对象间交换的消息

        顺序图能够加强产品经理、开发、测试之间对系统功能的进一步了解,通过顺序图我们能够全貌的了解到系统的流程,为我们后续进行测试设计打下了坚实的基础。

        顺序图除了能够对需求进行分析外,还可以完成很多我们工作上的其他内容,譬如梳理部门的工作流规范(Bug流程、提测流程、用例评审流程、用例编写流程等),甚至可以对部门角色的职能描述。

二、顺序图中的符号

        顺序图有四部分:参与者(Actor)或对象(Object)、生命线(Lift Line) 、激活期消息

   

1、参与者(Actor) / 对象(Object)

参与者与对象按照一定顺序从做到右排列。UML中并没有对排列顺序作出任何要求,但是经过长期的积累得出以下经验:

  1. 活动的起始点放在最左侧。
  2. 交互频繁的参与者或对象靠拢。

在UML中,参与者通常使用以下表示方法:

actor 测试工程师 as te

participant 用例系统 as tcms

在UML中,对于参与者或对象,我们可以使用  as 来给对象起别名,方便后面的引用。
除了使用 actor 和 participant 声明参与者和对象外,还可以通过  boundarycontrolentity 和  database 来声明,仅图标差异。

2、生命线

每个参与者或对象都有生命线,生命线随着参与者的创建而产生,销毁而小时。当创建了参与者后,UML图上会顶部和底部各显示参与者,并且通过垂直虚线相连,这条垂直虚线就是生命线。

3、激活期

激活期是指对象在整个活动中获得了焦点,需要一段时间来执行某个动作,在UML图中是一个空心的矩形表示,其语法为:activate te

激活期是一个时间段,有开始就必要会结束,结束的语法为:deactivate te

在activate和deactivate之间就形成一个矩形,这就是激活期。

4、消息

对象之间的交互是通过相互发消息来实现的。一个对象通过发送消息请求另一个对象做事件。

消息从源对象指向目标对象。消息一旦发送便将控制从源对象转移到目标对象。

消息不仅可以从A对象发给B对象,还可以自己发给自己。
te -> dev : 提了个bug,赶紧解
activate dev
dev -> dev : 改bug中
dev --> te : 改完了,麻烦回归一下
deactivate dev

消息可以分为同步消息、异步消息以及返回消息。

4.1 同步消息

直到等待接收者返回消息,譬如 测试工程师 准备写测试用例,发了消息“给我需求文档”给产品经理,只有等待产品经理返回消息后,测试工程师才可以继续后续的操作。

在UML中,使用实心箭头

te -> pm : 需求文档

4.2 异步消息

无需等待,发送消息后继续操作。譬如 测试工程师 拿到需求文档后,发消息“给我详细设计文档”给 开发工程师,此时测试工程师不需要等开发工程师给详设文档,在开发准备的过程中进行验收用例设计。

在UML中,使用空心箭头

te ->> dev : 详设文档

4.3 返回消息

表示完成某个活动或动作后,给予消息源反馈内容。

在UML中,使用空心箭头

dev --> te : 详设文档

三、顺序图操作

1、 顺序图标题

通过 title 关键字为顺序图设定名字。

@startuml

title Bug简易流程

te -> dev : 提了个bug,赶紧解
activate dev
dev -> dev : 改bug中
dev --> te : 改完了,麻烦回归一下
deactivate dev

@enduml

2、 分割线

使用分割线可以把一个顺序图划分为不同的阶段。分割线使用 == 阶段名称 == 的形式来表示。

@startuml
actor 测试工程师 as te
actor 开发工程师 as dev
participant 用例系统 as  tcms
== 测试阶段 ==
== 改bug阶段 ==
== 回归阶段 ==
@enduml

3、注释

在UML图中描述的内容有限,需要通过注释配合说明才能达到更好的效果。

一个消息只能对应一个注释信息。
@startuml
te -> dev : 提了个bug,赶紧解
note left : 单行文本
te -> dev
note left 
多行文本
多行文本
多行文本
end note
@enduml
除使用 left 进行方位标记外,还可以使用 right 。

4、消息数字序号

当时序图中存在很多消息时,会产生很大的理解障碍。通过 autonumber 关键字,可以自动把消息按先后顺序加上数字序号。

@startuml
autonumber
title Bug简易流程
te -> dev : 提了个bug,赶紧解
activate dev
dev -> dev : 改bug中
dev --> te : 改完了,麻烦回归一下
deactivate dev
@enduml

5、分组

@startuml
autonumber
title 需求分析建议流程(不完全)

group 需求文档获取
    te -> pm : 需求文档 
    activate pm
    pm -> pm : 写需求文档
    pm -> te
    deactivate pm
end group

group 需求分析
    te ->> dev : 详细设计文档
    activate te

    group 需求澄清
        te -> te : 了解需求
        te -> te : 需求反串讲
    end group

    group 需求分析

    end group

    group 测试设计与分析

    end group

    deactivate te
end group
@enduml

6、条件判断

条件判断为顺序图提供了强大的逻辑判断能力,极大丰富了顺序图的使用范围。在UML中使用 alt 关键字来进行条件判断。

@startuml

title 提交bug规范

te -> dev : 提交bug
dev -> dev : 查看bug信息

alt bug规范

dev -> dev : 修改bug
dev -> te : 修改完成,回归

else bug不规范

dev --> te : 无效bug,信息不完整,重新提

end

@enduml

alt 是一种特殊的group分组

7、循环

循环进行某一项活动,在UML中使用 loop 关键字对内部活动进行循环操作,直到条件满足后退出。

@startuml
title 提交bug

te -> te : 探索性测试

loop 直到提交完毕
    te -> JIRA系统 : 提交一个bug
    JIRA系统 --> te : 提交成功
end

@enduml

loop 是一种特殊的group分组

8、延时

在两条消息之间添加延时,可以提高顺序图的阅读性。在UML中使用 … 来添加时延。

@startuml
title 回归测试

te -> dev: 提交bug

dev -> dev : 修改bug
dev --> te : 修改完成,提交测试

... 回归测试(一天) ...

te -> dev : 回归不通过,重新改下bug

@enduml

9、参与组分组

@startuml
title 参与者分类

box 人类军团 #LightGreen
    actor 软件测试工程师 as te
    actor 开发工程师 as dev
end box

participant 用例系统 as tcms
@enduml

四、示例

1、机房用户登录

2、上班打卡的顺序图

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/zhaxun/article/details/124267909

智能推荐

Android逆向学习(1)--记一次破解某直播盒子App-程序员宅基地

文章浏览阅读1.2w次,点赞4次,收藏40次。打击违法直播 净化网络环境某天,我的一个朋友(这个朋友真不是我自己)发了我一款聚合直播App,大喜过望之后发现需要充值才能继续观看,我这种穷逼哪来的钱充值,所以就有了这次逆向之旅一、反编译用jadx-gui直接打开Apk,发现没有加固,源码如下:二、源码分析1. 打开app,通过adb查看当前activity的名称adb shelldumpsys a...

最新饿了么电脑脚本+获取cookie教程+代挂_饿了么乐园币脚本-程序员宅基地

文章浏览阅读1.8w次,点赞2次,收藏25次。最新9月份饿了么电脑脚本薅羊毛+获取cookie教程+免费代挂,脚本交流,脚本分享,代挂饿了么豆子,免费_饿了么乐园币脚本

vue简单使用mock模拟后台数据_vebn mock-程序员宅基地

文章浏览阅读2.3k次,点赞3次,收藏6次。下载npm install mockjs --save-dev使用1、新建mock.jsimport Mock from 'mockjs'Mock.mock("/getTest",{ "name1|1-3": 'a', "name2|2": 'b',});2、新建vue文件<template> <div> ..._vebn mock

error C2664: 不能将参数 1 从“WCHAR [260]”转换为“const char *”_无法将参数 1 从“wchar [260]”转换为“const char *”-程序员宅基地

文章浏览阅读5.8k次。解决方法:1、vs2010 项目-> XXX属性-> 配置属性-> 常规-> 字符集 -> “使用unicode字符集” 改为 “未设置” 就去掉了unicode支持;(已经验证过)2、也可以在#include 之前加上一句#undef UNICODE 有时候好像不太管用3、你全部使用 TCHAR替换char字符串常_无法将参数 1 从“wchar [260]”转换为“const char *”

MIDI文件结构分析及生成方法(转)-程序员宅基地

文章浏览阅读1.7k次。从网上找的,已经将用bc写的改成了vc的,由于对音乐的理解比乐盲还差,对于程序中转换是否有问题我也不得而知,反正用vc生成的midi文件听起来惨不忍睹。  对于制作midi音乐来说,比播放midi文件本身更复杂得多。我们得了解..._midi数据结构

新能源汽车行业-某新能源汽车全国30个4S店全国sdwan组网-云直连介入阿里云_4s店 sdwan-程序员宅基地

文章浏览阅读1k次。客户需求分析:客户全国30个门店通过SDWAN线路访问阿里云服务器。 接入阿里云预计需求是100M带宽,每个门店10M带宽。 Telstra提供全国网络资源实现门店到阿里云的网络连通,搭建稳定可靠的SDWAN网络,客户SDWAN网络主要使用的应理类系统和销售应用系统。 解决方案说明1,客户共有阿里云和30个门店共31个节点的网络需求。2,Te..._4s店 sdwan

随便推点

日常笔记_若x是搜索树的根节点,则x是割点当且仅当搜索树上存在至少两个子节点-程序员宅基地

文章浏览阅读179次。目录一 树上差分:二 tarjan算法求割边三tarjan求割点四 康托展开 五 后缀数组模板:六 后缀自动机模板:七 求最大子矩阵八 异或空间,线性基九 极大团(回溯法 剪枝)十 斯坦纳树 求给定点的最小联通代价十一 FFT(多项式乘法)十二 NTT十三回文树(统计回文串的数量)十四广义后缀自动机十五 欧拉回路十..._若x是搜索树的根节点,则x是割点当且仅当搜索树上存在至少两个子节点

2122 数据结构实验之链表七:单链表中重复元素的删除_2122数据结构式-程序员宅基地

文章浏览阅读434次。数据结构实验之链表七:单链表中重复元素的删除Time Limit: 1000MS Memory Limit: 65536KBProblem Description按照数据输入的相反顺序(逆位序)建立一个单链表,并将单链表中重复的元素删除(值相同的元素只保留最后输入的一个)。Input第一行输入元素个数 n (1 第二行输入 n 个整数,保证在 int 范_2122数据结构式

计算机维护常用软件有哪些-程序员宅基地

文章浏览阅读1k次。桌面运维的工作非常繁杂,在完成日程工作以外还要应对各种突发事件。该职业要求具有极高的响应能力,以便快速的解决故障以保证它人的工作可以顺利进行。对于从事桌面运维的工程师来说,具备高度的计算机理论知识和和一些运维工具是必不可少的。而运维人员可能遇到以下一些问题,IT管理员常用的管理,运维工具有哪些计算机维护常用软件有哪些电脑桌面运维工程师需要做些什么?常用电脑维修工具都有那些?运维人员必备工具教程..._1.计算机维修与维护常用的工具有哪些? (最少写 五个)

POI excel添加数据有效性验证以及解决DataValidation超长的问题_xssfdatavalidationconstraint-程序员宅基地

文章浏览阅读1.1w次,点赞7次,收藏20次。背景业务功能的需要,要求要去生产一个带有数据校验的导入模板。了解工具XSSFDataValidationConstraint(XSSF数据有效性验证约束):创建约束的时候,可以指定数据类型,以及数据列。例如:String strFormula = hiddenSheetName + "!$"+colStr+"$1:$"+colStr+"$65535"; XSSFDataValidationConstraint constraint = new XSSFDat_xssfdatavalidationconstraint

python数据怎么传递给html_让数据流通在Html Java Python-程序员宅基地

文章浏览阅读2.3k次。一、介绍首先说一下为什么需要让数据在Html Java Python之间流通。前端Html使用的thymeleafSpring BootFastAPI目前有一个数据分析的功能,要求从html前端接受数据,后台进行处理。但是Java直接做数据分析是不太方便的,所以这里想接入Python来做。接入Python调查到有两种方式,但是都有其局限性,Java调用Python脚本。直接写好Python脚本,然..._python把数据传给html

[c++]随机生成四个数字,计算24点,并输出算式_用c++实现四个数的任意24+问题代码-程序员宅基地

文章浏览阅读6.6k次,点赞4次,收藏10次。此次程序使用了“ctime”头文件,用来获取时间,用rand()函数生成随机数,“srand((unsigned)time(NULL));”此语句可以生成随时间变化的随机数。计算出结果后,用户可以选择继续输出或者停止。代码如下://主要功能:随机生成四个1~13之间的数字,进行24点运算,输出所有成立的算式。#include "stdafx.h"#include "iostream"#incl_用c++实现四个数的任意24+问题代码

推荐文章

热门文章

相关标签