快速入门UML时序图

使用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人西天取经的超简化版为例,画出取经过程的时序图。
westJourney

  • 9
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值