前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >UML状态图详解

UML状态图详解

作者头像
xxpcb
发布2023-08-22 09:28:06
8590
发布2023-08-22 09:28:06
举报
文章被收录于专栏:码农爱学习的专栏

本篇,来继续介绍UML中的另一种图——状态图。

1 UML状态图简介

状态图,显示一个状态机,属于UML活动图。

UML具有许多不同类型的图表,包括:

  • 静态图:用例图、类图、包图
  • 动态图:活动图、状态图、时序图、协作图

状态机用于对模型元素的动态行为进行建模,或是说对系统中受事件驱动的方面进行建模。

2 状态图基本要素

2.1 状态

状态是状态机的重要组成部分,描述了状态机所在对象动态行为的执行所产生的结果

2.1.1 初始/最终/选择状态

这三个都是伪状态(Pseudostate):

  • 初始状态:用一个实心圆形表
  • 最终状态:用一个圆圈内嵌实心圆点表示
  • 选择状态:用一个菱形表示,条件分支上方括号内的文字表示监护条件(guard conditions)

2.1.2 一般状态

UML中使用一个圆角矩形表示一个一般状态

状态的组成部分:

  • 名称:由一个字符串组成,用以识别不同状态。可匿名,一般放置在状态图符顶部
  • 入口/出口动作:表示进入/退出这个状态所执行的动作,动作可以是原子动作,也可是动作序列
  • 内部转换:内部转换不会引起状态变化的转换,此转换的触发不会导致状态的入口/出口动作被执行。语法:事件/动作表达式

2.1.3 复合状态

复合状态,或称组合状态,是指包含有子状态的状态。

如下图,“复合状态2”即为复合状态,内部的“状态2-1”、"状态2-2"为子状态。

也可用以下形式表示,将复合状态的内容单独画出。

注:图中的圆圈内一个H字母,表示历史状态,它也是一个伪状态,其目的是记住从组合状态中退出时所处的子状态,当再次进入组合状态,可直接进入这个子状态,而不是再次从组合状态的初态开始

2.2 转换

转换(Transition)是两个状态之间的关联。表示对象在第一个状态(Source State)中执行一定的动作,并在某个特定事情发生并且某个特定的条件满足时进入下一个状态(Target State)。

2.2.1 一般转换

一般情况下的状态转换是两个不同状态之间的转换,示意图如下:

转换的组成部分:

  • 源状态(Source State):源状态就是被转换影响的状态。某对象处于源状态,当它接收到触发事件或满足监护条件,就会激活一个转换
  • 目标状态(Target State):转换完成后,对象状态发生变化,这时对象所处的状态就是转换的目标状态
  • 触发事件(Trigger):引起转换的事件,这里所指的事件可以是信号、调用、时间段或状态的一个改变
  • 监护条件(Guard Condition):是一个方括号括起来的布尔表达式,它被放在触发事件的后面。监护条件可以引用对象的属性值和触发事件的参数
  • 结果(Effect):对象状态转移后的结果

2.2.2 自身转换

自身转换(Self-Transitions),是指状态可以有返回自身状态的转换。

2.2.3 内部转换与外部转换

对于复合状态之间的转换,需要注意内部转换(Local transition)与外部转换(External transition)的不同。

上图中,左边是本地转换,右边是外部转换。

  • 上面两个,源状态包含了目标状态,这种情况两种转换的区别在于:本地转换不会从源状态退出(不会执行退出动作),而外部转换会退出再重新进入源状态。
  • 下面两个,目标状态包含了源状态,这种情况两种转换的区别在于:本地转换不会再次进入目标状态(不会执行进入动作),而外部转换会退出再重新进入目标状态。

3 一个UML状态图实例

3.1 使用visio绘制UML状态图

新建一个visio文件,打开后会自动提示选择创建某种类型的图,这里选择"软件和数据库 ->UML状态机"

点击确定之后,会进入UML状态图的编辑界面,左侧可以看到用于UML状态图编辑的基本元素,将这些元素拖拽到右侧的编解面板中,可以看到这些元素的基本结构形式:

3.2 实例讲解

下面是一个UML状态图的实例:

这是一个全自动洗衣机的UML状态图,主要包括“设置”、“工作中”、“暂停”这3个状态。

  • 开机时,会先进入“设置”状态,可以设置洗衣模式以及水量等,触发启动后,会进入“工作中”状态。
  • “工作中”是一个复合状态,内部包括“加水”、“清洗”、“排水”、“甩干”这4个子状态。进入该状态后,从“加水”子状态开始执行,然后会执行“清洗”、"排水"子状态,排水完成后,根据清洗次数是否足够,跳转到“加水”或“甩干”子状态。
  • 在“工作中”状态时,无论处于哪个子状态,只有按了暂停键,都会进入“暂停”状态,再按继续,则会进入“工作中”继续执行,注意继续时指向的是历史状态(圆圈内一个H字母),表示继续指向刚才暂停时的子状态。

4 总结

本篇介绍了UML状态图的基础知识,并通过visio绘制一个全自动洗衣机的UML状态图实例,来介绍UML状态图的画法与所表达的含义。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-05-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码农爱学习 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 UML状态图简介
  • 2 状态图基本要素
    • 2.1 状态
      • 2.1.1 初始/最终/选择状态
      • 2.1.2 一般状态
      • 2.1.3 复合状态
    • 2.2 转换
      • 2.2.1 一般转换
      • 2.2.2 自身转换
      • 2.2.3 内部转换与外部转换
  • 3 一个UML状态图实例
    • 3.1 使用visio绘制UML状态图
      • 3.2 实例讲解
      • 4 总结
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档