《软件方法》强化自测题-分析(7)

2024-01-11 00:52

本文主要是介绍《软件方法》强化自测题-分析(7),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DDD领域驱动设计批评文集

做强化自测题获得“软件方法建模师”称号

《软件方法》各章合集

按照业务建模、需求、分析、设计工作流考察,答案不直接给出,可访问自测链接或扫二维码自测,做到全对才能知道答案。

知识点见《软件方法》(http://www.umlchina.com/url/softmeth.html)、

“软件需求设计方法学全程实例剖析”幻灯片(http://www.umlchina.com/training/slide.html)以及UMLChina公众号文章。

自测链接:https://www.101test.com/cand/index?paperId=E2RL7N


1. [单选]

一名精读《软件方法》的建模人员,在使用类图整理素材中的领域知识。他阅读到文字“缺货的商品”,此时最合理的整理是:

 A) 

 

图片

 B) 

图片

 C) 

图片

 D) 

图片

2. [多选]

你是一名精读《软件方法》的建模人员,在使用类图整理素材中的领域知识。

这天,你在整理一张类似下面的出库单: 

图片

你按照《软件方法》中的建模指南,把领域知识分成了无冗余的、通过关系连接起来的很多个类。

这时,有同事看到后反应激烈,唧唧歪歪“会影响性能”、“我们之前不是这样做的”等等。

针对这种情况,以下符合《软件方法》推荐的应对有:

 A) 甩给他另外一个素材,让他像你这样做一个无冗余的模型看看。如果他做得出来,可以和他认真研讨,如果他做不出来,就让他闭嘴。

 B) 虚怀若谷,兼容并包,考虑他的意见,折衷修改。

 C) 意识到这位可能是一个脓包,平时多留心收集资料,为必要时亮剑做准备。

 D) 引用鲁迅的“从来如此,便对么?”来反驳他。

3. [单选]

很久以来,我们会对很多东西赋予惟一的编号,而且这些编号后面隐藏着领域知识。例如,房间号“405”暗示这可能是4楼第5个房间,人员身份证号“1100************”暗示这可能是一个北京人。

这样编号的目的是:

 A) 方便计算机记忆和检索

 B) 方便人类记忆和检索

 C) 方便计算机解析隐藏的领域知识

 D) 方便在关系数据库中作为主键使用

4. [单选]

我们观察用中文来命名模型元素的类模型或关系数据库模型,可能会发现有很多名字最后有“单”、“记录”、“信息”、“事件”、“历史”等后缀,例如“采购单”、“支付记录”、“出库信息”——当然,这是不好的。

如果观察用英文来命名模型元素的类模型或关系数据库模型,会发现这样的情况相对较少,原因是:

 A) 汉语更精炼,加上这些后缀使得含义更加丰富,不同的后缀有微妙的不同。

 B) 汉语没有单复数。

 C) 面向对象建模或关系数据库建模起源于英语国家,所以从业人员整体素质更高。

 D) 英语的动词转化为名词时往往会有变化。

5. [多选]

下图是“Domain-Driven Design: Tackling Complexity in the Heart of Software”中的一张类图,请问类的名称中没有带来有价值的额外信息可以删掉的文字有: 

图片

 A) History

 B) Movement

 C) Event

 D) Specification

6. [单选]

下图源自某本软件开发书籍,用EA原样复刻。

抛开其他方面的问题不谈,只谈类名和属性名。

如果在不修改类个数的情况下,删除冗余属性、类名和属性名中的冗余内容,大概有多少比例的内容可以删除?计算方法:(被删除的类名和属性名字数/图中原有的类名和属性名字数)×100%,2个英文字符算一个字。

图片

 A) 36%

 B) 46%

 C) 56%

 D) 66%

7. [单选]

建模人员小帅在研究物流领域的素材时,为了更好理解领域知识,他画了一张UML类图来整理各种领域概念,如仓库、库存、出库、入库、配送、配送员、地址等。

小帅还想用序列图来整理素材,帮助理解领域知识。以下说法正确的是:

 A) 用序列图来整理素材会带来帮助,但序列图上生命线对应的类大概率不是之前所画类图上的类。

 B) 用序列图来整理素材会带来帮助,但序列图上应该保持纯领域内容,不能出现任何与计算机、网络相关的概念,之前所画类图上的类如果涉及到这些内容,尽量不要在序列图中使用。

 C) 序列图是很多年前的方法,已经过时了,可以使用革命性创新和划时代洞见的领域驱动设计连续流程业务领域用户需求架构分析风暴敏捷画布。

 D) 更合适的图是活动图,因为序列图是面向对象的思想,而此时并没有对象。

8. [多选]

很多革命性划时代领域驱动设计创新有投资少、见效快、产量高等特点。

以下选项的图形中,有一些也向领域驱动设计学习,它们是:

 A)  

图片

 B)  

图片

 C)  

图片

 D)  

图片

9. [单选]

近日有专家称“养娃难,可求助亲戚”。如果这位专家按照他自己这句话的味道来做类建模,最有可能会发生什么情况? 

图片

 A) 泛化和关联不分

 B) 类和角色不分

 C) 属性和状态不分

 D) 聚合和组合不分

10. [单选]

下图源自某本软件开发书籍,用EA原样复刻。

 

图片

近日有专家称“养娃难,可求助亲戚”。

 

图片

抛开其他方面的问题不谈,类图中哪个类和专家这句话的韵味相似?

 A) 商品信息

 B) 子订单信息

 C) 支付流水

 D) 收货人

UMLChina公众号精选(20240108更新)

这篇关于《软件方法》强化自测题-分析(7)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/592630

相关文章

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

Spring Boot从main方法到内嵌Tomcat的全过程(自动化流程)

《SpringBoot从main方法到内嵌Tomcat的全过程(自动化流程)》SpringBoot启动始于main方法,创建SpringApplication实例,初始化上下文,准备环境,刷新容器并... 目录1. 入口:main方法2. SpringApplication初始化2.1 构造阶段3. 运行阶