快速入门UML时序图「建议收藏」

2022-09-07 10:48:10 浏览数 (1)

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

使用UML时序图重构代码

  • 使用UML时序图
    • 时序图是什么
    • 时序图的元素
    • 组合块(Combined Fragment)
    • 举例

使用UML时序图

最近,在重构项目中的老代码的时候,业务复杂,文档缺失。抽丝剥茧,沉迷在剪不断理还乱的纷繁的关系中,像是苏东坡诗中的那只高贵的乌鸦先生找不到落脚之处。披沙拣金,终于理出一点头绪,生怕忘了,赶紧记下来,又苦于没有好的方式去表达这些错杂的关系,蓦然发现,UML时序图是表达业务动态关系的好工具。赶紧来学习一下这个工具。

时序图是什么

时序图(Sequence Diagram)是一种流行的动态建模方案,基于时间顺序去表征对象之间的交互关系,并且使用统一建模语言(UML)去表达时序关系。 时序图的特点:

  • 表征业务的具体细节
  • 对复杂的调用、函数和操作的逻辑关系进行建模
  • 表明对象、组件之间是如何交互的
  • 理解旧代码,规划新场景

时序图的元素

以 StarUML为例。 角色(Actor)。 人或其他系统角色。 生命线(Lifeline)。 从对象图标向下延伸的一条虚线,表示对象存在的时间。如下图,分别对应三种生命线:对象、匿名对象、集合中的指定对象。

执行(Execution)。 即两个对象之间的交互,请求或相应。小矩形为对于请求的执行过程,执行结束后返回给请求方。消息分为同步消息和异步消息两种,同步消息的末端箭头为黑色实心的,异步消息的末端箭头为空心的。

自调用消息:

创建类消息(Create Message):

删除类消息(Delete Message)。对于删除消息,被删除的对象的生命线就会结束。

组合块(Combined Fragment)

组合块是一系列同类交互动作的组合,分支、选择、循环或并行等动作的组合。

  • alternative fragment(denoted “alt”) 与 if…else对应
  • option fragment (denoted “opt”) 与 switch对应
  • parallel fragment (denoted “par”) 表示并发
  • loop fragment(denoted “loop”) 与 for 、while或者 foreach对应
  • break fragment (“break” ) 与 for … break 或 while…break对应
  • critical fragment (“critical”) 并发执行时访问临界资源
  • assert fragment (“assert”) 断言,执行动作之前先进行判断,符合判定条件才继续执行
  • strict fragment (“strict”) 强有序,几个动作的执行严格遵循一定的顺序(不在同一条生命线也要遵循有序性)
  • seq fragment (“seq”) 弱有序,不在同一条生命线上的操作的顺序任意,在同一条生命线上的操作严格有序
  • ignore fragment (“ignore{item1, item2, …}”) 忽略指定操作
  • consider fragment (“consider{item1, item2, …}”) 除指定操作外,忽略其他操作
  • neg fragment (“neg”) 当系统失败(超时或宕机)时的操作为negative 每种类型组合图例参考这里:Sequence Diagrams Reference

举例

以唐僧师徒4人西天取经的超简化版为例,画出取经过程的时序图。

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

0 人点赞