ADMEMS推荐以鲁棒图来辅助初步设计。那么,什么是鲁棒图呢?
鲁棒图包含3中元素,它们分别是边界对象、控制对象、实体对象。
- 边界对象对模拟外部环境和内部系统之间的交互进行建模。边界对象负责接收外部输入,处理内部内容的解释,并表达或传递相应的结果。
- 控制对象对行为进行封装,描述用例中事件流的控制行为。
- 实体对象对信息进行描述,它往往来自领域概念和领域模型中的对象有良好的对应关系。
因为“类比思维”在人的头脑中是根深蒂固的,关于鲁棒图3元素的“类比”,自然是MVC。我们做了全面的对比,两者之间还是有不小的差异的。
鲁棒3元素和MVC的主要不同在于:
- View仅涵盖了“用户界面”元素的抽象,而鲁棒图的边界对象全面涵盖了三种交互,即本系统和外部“人”的交互、本系统与外部“系统”的交互、本系统与外部“设备”的交互。
- 数据访问逻辑Controller吗?不是。控制对象广泛涵盖了应用逻辑、业务逻辑、数据访问逻辑的抽象,而MVC的Controller主要对应于应用逻辑。
- MVC的Model对应于经典的业务逻辑部分,而鲁棒图的实体对象更像“数据”的代名词--用实体对象建模的数据既可以是持久化的,也可以仅存在内存中,并不像有的实践者理解的那样直接就等同于持久化对象。
如银行存储系统的“销户”功能的鲁棒图。
为了实现销户的功能,银行工作人员要访问3个边界对象:
- 活期账号销户界面
- 磁卡读取设备
- 打印设备
“销户”是一个“控制对象”,和“计算利息”一起进行销户功能的逻辑控制。
- 其中,“计算利息”对“活期账户”、“利息率”、“利息税率”这3个“实体对象”进行读取操作。
- 而“销户”负责读出“客户资料”......最终销户的完成意味着写入“活期账号”和“销户流式”信息。
鲁棒图(Robustness Diagram
)是由Ivar Jacobson于1991年发明的,用以回答“每个用例都需要哪些对象”的问题。
后来的UML
并没有将鲁棒图列入到UML
标准,而是作为UML
版型(stereotype
)进行支撑。
对于RUP
、ICONIX
等过程,鲁棒图都是重要的支撑技术。当然,这些过程反过来也促进了鲁棒图技术的传播。
那为什么叫鲁棒图?它和鲁棒性有什么关系?
答案是:词汇相同,含义不同。
软件系统的”鲁棒性(
Robustness
)“也是经常被翻译成”健壮性“,它同时和”容错性(Fault Tolerance
)“含义相同。具体而言,鲁棒性指当下发生时依然具有正确运行功能的能力:非法输入数据、软硬件单元出现故障、未料到的操作情况。
鲁棒图的作用有两点:
- 初步设计
- 检查用例规约是否正确和完善
”鲁棒图“正是因为第2点作用而得名的--所以,严格来讲”鲁棒图(
Robustness Digagram
)“所指的不是"鲁棒性(Robustness
)"。
从Doug Rosenberg
在《用例驱动的UML对象建模应用》的描述中,也可得到上述结论:
在
ICONIX
过程中,鲁棒分析扮演了多个必不可少的角色。通过鲁棒分析,您将改进用例文本和静态模型。
- 有助于区别用例文本的正确性,且没有指定不合理或不可能的系统行为(基于要使用的一组对象),从而提供了健康性检查(
Sanity Check
)。这种改进使用用例文本的特性从纯粹的用户手册角度变成对象模型上下文中的使用描述。- 有助于区别用例考虑到所有必须的分支流程,从而提供了完整的正确性检查。经验表明,为实现这种目标,并编写出遵循某些定义良好的指南的问题,而在绘制鲁棒图上花费的时间,将在绘制时序图时3-4倍的节省下来。
- 有利于发现对象,这一点很重要,因为在建模期间肯定会遗漏一些对象。你还可以发现对象命名冲突的情况,从而避免进一步造成严重的问题。另外,鲁棒分析有利于确保我们在绘制时序图之前确定大部分实体类和边界类。
不要再困惑于类似”鲁棒图是分析技术,还是设计技术“这样的问题了。大家只需要记住两个公式:
- 需求分析 ≠ 系统分析
- 系统分析 ≈ 初步分析
关于”分析“和”设计“的区分,在《面向对象的系统设计》一书中早已做过精彩的阐述:
在”做什么“和”怎么做“来区分分析与设计,是从结构化方法沿袭过来的一种观点,但即使在结构化方法沿袭过来的一种观点,但即使在结构化方法中这种说法也很勉强......
在”做什么“和”怎么做“为什么会出现上述矛盾?究其根源,在于人们对软件工程中”分析“这个术语的含义有着不同的理解--有时把它作为需求分析(
Requirements Analysis
)的简称,有时又指系统分析(Systems Analysis
),有时则作为需求分析和系统分析的总称。需求分析时软件工程学中的经典术语之一,名副其实的含义应是对用户需求进行分析,旨在产生一份明确、规范的需求定义。从这个意义上讲,”分析是解决做什么而不是解决怎么做“是无可挑剔的。
但迄今为止,在人们提出的各种分析方法(包括结构化分析和面向对象分析)中,真正属于需求分析的内容所占的分量并不大;更多的内容是给出一种系统建模方法(包括一种表示法和相应的建模过程指导),告诉分析员如何建立一个能够满足(由需求定义所描述的)用户需求的系统模型。分析员大量的工作是对系统的应用领域模型进行调查研究,并抽象表示这个系统。确切的讲,这些工作应该叫做系统分析,而不是需求分析。它既是对“做什么”问题的进一步明确,也在相当程度上设计“怎么做”的问题。
忽略分析、需求分析和系统分析这些术语的不同含义,并在讨论中将它们随意替换,是造成上述矛盾的根源。
至于实践者为什么常将“需求分析”和“系统分析”混淆,这背后有着重要的现实原因。实际的工程化实践中,需求捕获、需求分析、系统分析并不是完全孤立进行的。想法,它们往往是相互伴随、交叉进行的。需求工作伊始,无疑更多是进行需求捕获工作,相伴进行的需求分析工作所占的比例偏少;但随着掌握的需求信息越来越多,我们需要开展对需求的分析和整理工作也越来越多了;而此时,伴随着对问题的分析,自然而然会在高层次提出相应的应对策略......这恰恰就是系统分析工作。
《软件架构设计》一书中有如下阐述:
需求捕获是获取知识的过程,知识从无到有,葱烧到多。需求采集者必须立即用户所充实的工作,并了解用户客户希望软件系统在哪个方面能够帮助他们。
需求分析是挖掘和整理知识的过程,它在已掌握知识的基础上进行。毕竟,初步捕获到的需求信息往往处于不同的层次,也有一些主观深圳不正确的信息。而经过必要的需求分析工作之后,需求更加系统、更加有条理、更加全面。
那么系统分析呢?如果说,需求分析致力于搞清楚软件系统要“做什么”的话,那么系统分析已经开始涉及“怎么做”的问题了。
《系统分析与设计方法》一书中写道:
简单的说,系统分析的意义如下:“系统分析是针对系统所要面临的问题,搜集相关的资料,以了解产生问题的原因所在,进而提出解决问题的方法和可行的逻辑方案,以满足系统的需求,实现预定的目标。”
需求捕获、需求分析,以及系统分析之间的关系,我们必须理解透彻,否则会影响工作的有效进行。
再次强调,鲁棒图已经“打开”了“系统”这个“黑盒子”,将它划分成很多的不同的职责,所以它是“设计技术”。