UML时序图简析[通俗易懂]

UML时序图简析[通俗易懂]前言在嵌入式软件开发中,必然会遇到与其他控制板卡或者服务器通信的情况。比如,制作一个无线远程控制系统。系统分为,输入设备,云端服务器,执行设备。其中输入设备,用户可以通过设备上的触摸屏进行交互,控制或者监测远程设备云端服务器,收发终端,接收输入设备的命令,并将其转换为执行设备可识别的信号发送到可执行设备。执行设备,执行服务器发送过来的命令,并且反馈当前的设备的一些状态.简单如下图所示。一般,这样的系统需要多人共同协作完成,输入设备的开发人员负责输入设备开发,云端负责云端,执行端负责执行端

大家好,又见面了,我是你们的朋友全栈君。

前言

在嵌入式软件开发中,必然会遇到与其他控制板卡或者服务器通信的情况。比如,制作一个无线远程控制系统。
系统分为,输入设备,云端服务器,执行设备。其中

  • 输入设备,用户可以通过设备上的触摸屏进行交互,控制或者监测远程设备
  • 云端服务器,收发终端,接收输入设备的命令,并将其转换为执行设备可识别的信号发送到可执行设备。
  • 执行设备,执行服务器发送过来的命令,并且反馈当前的设备的一些状态.

简单如下图所示。
在这里插入图片描述
一般,这样的系统需要多人共同协作完成,输入设备的开发人员负责输入设备开发,云端负责云端,执行端负责执行端。那么必定要制定通信协议,让系统中的各个节点能够相互识别对方的信息。而通信协议都比较专业,涉及很深的技术细节,而且不直观。

怎么样能够简洁的描述这三个设备之间的通信交互过程呢?也方便让团队内部其他人员明白整个的交互过程,更方便于开会评审。

通常我们都会想到用流程图。流程图固然是好的,但还是不够直观,流程图重在表述系统内部的逻辑流程。描述多个设备之间通信交互过程还是不够直观。有没有其他更直观的方式呢。

uml序列图的出现就是为了解决上述问题。先不去了解序列图的相关概念,先看一个小的例子。

ATM机取钱交互流程

大家比较容易理解的一个模型就是ATM取钱模型。采用序列图描述整个流程如下:

在这里插入图片描述
仔细看下上面的图,哪怕没有任何编程经验的人是不是也能大致看的懂?这个系统实际上是分为3部分。终端ATM,服务器,个人账户数据库。

上述箭头代表了命令或者数据的流动方向。这样图形化的方式,很容易让人理解清楚整个系统的交互流程。接下来,看一下时序图的定义以及制作。

UML时序图定义

定义:时序图(Sequence Diagram),又名序列图、循序图,是一种UML交互图。它通过描述对象之间发送消息的时间顺序显示多个对象之间的动态协作。它可以表示用例的行为顺序,当执行一个用例行为时,其中的每条消息对应一个类操作或状态机中引起转换的触发事件。

上述定义来源于百度百科,从定义中可以看出,时序图就是用来描述系统内部多个对象之间交互过程的。

时序图元素

1、 角色(actor)

系统角色可以是人,或者其他系统。上述例子中的的角色就是人。

2、对象(object)

对象位于时序图的顶部,用一个方框标识。

3、生命线(lifeline)

时序图中每个对象底部中心都会绘制一条向下的垂直虚线,这就是对象的生命线。代表对象在一段时间内存在。

4、控制焦点(activation)

控制焦点标识时序图中的西乡执行一项操作的时期,在时序图中每条生命线上以比较窄的巨星代表活动期。

5、消息(message)

消息是对象直接交互的信息流,存在于时序图的两条生命线之间,用带箭头的线标识,箭头方向代表消息的传送方向。实线代表传送的消息(命令),虚线代表对象反馈的消息(返回值)。

组合片段

组合片段用于解决信息交互执行时的条件。比如if,else等条件判断。
初步学习的话只需要了解OPT片段,标识一个可能发生或者可能不发生的序列,可以在临界中指定序列发生的条件。

示例图中的3个方框就是opt。

示例标注如下:
请添加图片描述
这样理解起来就更清晰了。制作过程也很简单,找到对应的软件即可。时序图在描述对象之间交互逻辑上还是非常简单直观的。适合用在在写具体代码前,团队内部理清系统各个硬件节点交互逻辑的时候。

这样理清楚后,负责各个模块的都能对这个系统的交互有全面深入的理解。这样开发起来就更顺利,减少了返工,以及写代码过程中发现逻辑有问题,而又要拉团队成员一起再确定交互逻辑的情况。

UML时序图绘制软件drawio

时序图可以用viso,process on等软件绘制,但这些都要收费。这里推荐一款完全免费的作图工具,UML时序图只是其中的一个功能。

这个软件叫做drawio,分为网页版,以及客户端版。完全无需注册,直接就可以使用。
链接如下:
网页版,https://app.diagrams.net/网页版可以将文件保存到本地,格式可以保存为图片格式。
windows桌面版https://github.com/jgraph/drawio-desktop/releases最新版本为16.5.1

在这里插入图片描述

drawio软件操作

安装完成后,点击桌面图标启动软件。
在这里插入图片描述
显示界面如下所示
在这里插入图片描述
点击创建新绘图,选择UML,点击创建,可以玄策其中的模板,然后创建,也可以直接创建空白绘图。在这里创建的是空白绘图。
在这里插入图片描述
界面如下图所示:
在这里插入图片描述
可能一开始是左侧是没有UML和UML2.5菜单栏的。这是需要点击左下角的更多图形,进行UML图形添加,具体操作按照下图操作。

在这里插入图片描述
添加完后,界面上就可以看到左侧有UML,UML2.5图库。
在这里插入图片描述
直接点击或者拖动对应的图标到界面上就行了。要输入文字就选中要输入文字的对象,然后按enter键,测试过程中发现双击文字不好使。

在这里插入图片描述

常用快捷键

ctrl + r :切换箭头方向。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/149074.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Django(59)验证和授权「建议收藏」

    Django(59)验证和授权「建议收藏」验证和授权概述Django有一个内置的授权系统。他用来处理用户、分组、权限以及基于cookie的会话系统。Django的授权系统包括验证和授权两个部分。验证是验证这个用户是否是他声称的人(比如用户名

    2022年7月31日
    2
  • 旋转编码器工作原理图_编码器工作原理图解

    旋转编码器工作原理图_编码器工作原理图解一、旋转编码器的原理和特点:旋转编码器是集光机电技术于一体的速度位移传感器。当旋转编码器轴带动光栅盘旋转时,经发光元件发出的光被光栅盘狭缝切割成断续光线,并被接收元件接收产生初始信号。该信号经后继电路处理后,输出脉冲或代码信号。其特点是体积小,重量轻,品种多,功能全,频响高,分辨能力高,力矩小,耗能低,性能稳定,可靠使用寿命长等特点。1、增量式编码器增量…

    2022年10月1日
    0
  • icem划分网格步骤_ICEM CFD教程-icem网格划分教程

    icem划分网格步骤_ICEM CFD教程-icem网格划分教程ICEMCFD教程四面体网格对于复杂外形,ICEMCFDTetra具有如下优点:根据用户事先规定一些关键的点和曲线基于8叉树算法的网格生成,生成速度快,大约为1500cells/second无需表面的三角形划分,直接生成体网格四面体网格能够合并到混合网格中,并实施平滑操作单独区域的粗化和细化ICEMCFD的CAD(CATIAV4,UG,ProE,IGES,andP…

    2022年5月9日
    44
  • DBA整理的万字详解MySQL性能优化,值得收藏![通俗易懂]

    DBA整理的万字详解MySQL性能优化,值得收藏!

    2022年2月19日
    43
  • e5续订程序_office e5开发者

    e5续订程序_office e5开发者E5调用API续订服务:Microsoft365E5RenewX:功能性:网页访问部分继承于Microsoft365E5RenewWeb并做了部分改进,数据库改进现在支持单用户多运行账号;内核API调用继承于Microsoft365E5RenewPlus;可部署性:支持开放站点部署和私享部署,私享部署不再强制要求配置Https和OAuth平台兼容性:使用Asp.NetCore作为跨平台框架增适用于WindowsLinuxMacOS…

    2022年9月30日
    0
  • Mysql之Linux环境下如何彻底删除卸载Mysql

    Mysql之Linux环境下如何彻底删除卸载Mysql首先连接操作系统,切换到root用户。一、如果是使用yum安装的mysql,使用如下命令进行卸载(不能确定使用何种方式安装的mysql情况下,按后续步骤一一进行处理即可):#yumremovemysqlmysql-servermysql-libscompat-mysql51#rm-rf/var/lib/mysq#rm/etc/my.cnf使用rpm-qa|grepmysq…

    2022年6月18日
    34

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号