大家好,又见面了,我是你们的朋友全栈君。
使用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人西天取经的超简化版为例,画出取经过程的时序图。
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/147999.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...