不要“做着玩”-《软件方法》自测题解析015

2022-10-31 16:21:42 浏览数 (1)

DDD领域驱动设计批评文集>>

《软件方法》强化自测题集>>

《软件方法》各章合集>>

第1章自测题 Part3

9 [单选题]

以下说法正确的是:

A)在项目中可以只挑选一部分UML元素来使用

B) UML模型的最佳案例就是建模工具附带的例子

C)团队引进UML时,努力达到的最终目标应该是完整应用所有的UML元素

D) UML是软件开发人员和客户之间沟通的绝佳工具

答案和解析

 A) 正确选项。

书中文字:

建模人员只需要根据当前所开发系统的特点,从这个工具箱中选择合适的工具就可以,并不需要“完整地”使用UML。

 B) 错误选项。

书中文字:

有一些建模工具自带的案例模型会造成误解,一个模型里把所有的UML图都给用上了,但这是工具厂商出于展示其工具建模能力的目的而提供的,不可当真。

 C) 错误选项。

该用多少UML元素,视所开发系统的类型以及对系统的质量要求而定。

 D) 错误选项。

书中文字:

UML模型的目的是在软件组织内部沟通,不是为了和涉众沟通。如果受到“和涉众沟通”的影响,会导致迁就涉众的水平,模型质量大大下降——当然,这也正是某些人想要的遮羞布:不是我不想或者没有能力画得深刻一点,我是怕涉众看不懂!

以医院看病类比。给患者做CT、磁共振的目的是医疗团队内部使用,不是为了和患者沟通。不能因为患者稍微看得懂CT或者喜欢看CT就给他多做CT,患者看不懂或不喜欢CT就不做。

关于如何和涉众沟通,详见第7章。

10 [单选题]

以下说法正确的是:

A)功能很少的系统不需要建模

B)类很少的系统不需要建模

C)市场上已经有很多现存产品的系统不需要建模

D)不参加竞争的系统不需要建模

答案和解析

 A) 错误选项。

功能很少,但该功能从输入到输出的转换逻辑可能非常复杂。

以下是彩蛋:

另外,“功能”是一个模糊用语,更严谨的是“用例”、“步骤”。不过,即使把“功能”换成“用例”,这句话也是不对的。

在同一愿景下,用例少的系统可能要比用例多的系统更复杂。

例如,愿景是为了减少做任务时出现的错误。

改进方案一的业务序列图如图1:

图1 改进方案一的业务序列图

从图1可以看出,在业务流程中的很多地方借助了人脑的思考。

竞品系统一的用例图如图2,有3个用例。

图2 竞品系统一的用例图

改进方案二的业务序列图如图3:

图3 改进方案二的业务序列图

从图3可以看出,岗位甲乙丙的责任已被转移到竞品系统二里面。你说啥?为什么还要岗位甲,领导干嘛不直接用系统做任务?你说呢?

竞品系统二的用例图如图4,只有1个用例。

图4 竞品系统二的用例图

假设这两个都可以满足愿景,您可以对比一下,哪个流程中的信息系统更复杂?

 B) 错误选项。

类很少,但类之间的协作方式可能非常多和复杂。

 C) 错误选项。

所有系统在问世之前,市场上都是“已经有很多现存产品”的,最原始的“竞品”就是“人脑系统”。

 D) 正确选项。

如果随便做做,不参与竞争,不会感觉到建模的必要,怎么做都可以找出各种理由自圆其说这样做是合理的。

就像打麻将,如果不耍钱或者只是一两块钱,出牌可能会“敏捷”得很,如果输了要剁手指,那么,每次出牌都要仔细盘算了。这个时候才会书到有时方恨少,后悔之前没好好练习算牌的技能。

因此,在最后讲到改进指南时,我们都会强调不要“做着玩”。

要么做UMLChina出的题目,因为那些题目有清楚的约束条件,指引你去得到最佳答案;

要么做真实的项目,因为真实项目也有清晰的约束条件——就是惟一的真实情况,它会指引或强迫你尽力去得到最佳答案。

[新增产品经理学习专用集锦]25套UML EA和StarUML的建模示范视频-全程字幕(20220901更新)

9月12-16晚网课[改为19:30上课*5天]:软件需求设计方法学全程实例剖析

10月10-14晚网课:SysML和MBSE基于模型的系统工程

《软件方法》书中自测题-题目全文 分卷自测(1-8章)16套111题

《软件方法》强化自测题集110题

CTO也糊涂的常用术语:功能模块、业务架构、用户需求……[20210217更新]

如何选择UMLChina服务

作者微信:umlchina2

uml

0 人点赞