2017年上半年计算机水平考试(中级)《软件设计师》真题(下午考卷)及答案 联系客服

发布时间 : 星期一 文章2017年上半年计算机水平考试(中级)《软件设计师》真题(下午考卷)及答案更新完毕开始阅读587f5a04690203d8ce2f0066f5335a8103d26674

2017年上半年计算机水平考试(中级) 《软件设计师》真题(下午考卷)

(总分100, 考试时间90分钟)

1. 试题一

阅读下列说明和图,回答问题1至问题4,将解答填入答题纸的对应栏内。 【说明】

某医疗器械公司作为复杂医疗产品的集成商,必须保持高质量部件的及时供应。为了实现这一目标,该公司欲开发一采购系统。系统的主要功能如下:

1.检查库存水平。采购部门每天检查部件库存量,当特定部件的库存量降至其订货点时,返回低存量部件及库存量。

2.下达采购订单。采购部门针对低存量部件及库存量提交采购请求,向其供应商(通过供应商文件访问供应商数据)下达采购订单,并存储于采购订单文件中。

3. 交运部件。当供应商提交提单并交运部件时,运输和接收(S/R)部门通过执行以下三步过程接收货物:

(1)验证装运部件。通过访问采购订单并将其与提单进行比较来验证装运的部件,并将提单信息发给 S/R 职员。 如果收货部件项目出现在采购订单和提单上,则已验证的提单和收货部件项目将被送去检验。否则,将S/R职员提交的装运错误信息生成装运错误通知发送给供应商。

(2) 检验部件质量。通过访问质量标准来检查装运部件的质量,并将己验证的提单发给检验员。如果部件满足所有质量标准,则将其添加到接受的部件列表用于更新部件库存。如果部件未通过检查,则将检验员创建的缺陷装运信息生成缺陷装运通知发送给供应商。

(3)更新部件库存。库管员根据收到的接受的部件列表添加本次采购数量,与原有库存量累加来更新库存部件中的库存量。标记订单采购完成。

现采用结构化方法对该采购系统进行分析与设计,获得如图1-1 所示的上下文数据流图和图 1-2 所示的 0 层数据流图。

图1-2 0层数据流图

1. 问题:1.1 使用说明中的词语,给出图1-1中的实体E1~E5 该问题分值: 4 答案:E1 供应商 E2 采购部门 E3 检验员 E4 库管员 E5 S/R职员

2. 问题:1.2 使用说明中的词语,给出图1-2中的数据存储D1~D4的名称。 该问题分值: 4 答案:D1 库存表 D2 采购订单表 D3 质量标准表 D4 供应商表

3. 问题:1.3 根据说明和图中术语,补充图1-2中缺失的数据流及其起点和终点。 该问题分值: 4

答案:装运错误通知:P3(验证装运部件)-----E1(客户) 缺陷装运通知:P4(校验部件质量)-----E1(客户)

产品检验:P3(验证装运部件)------ P4(校验部件质量) 检查库存信息:P1(检查库存水平)-----D1(库存表)

4. 问题:1.4 用 200 字以内文字,说明建模图 1-1 和图 1-2 时如何保持数据流图平衡。

该问题分值: 4

答案:父图中某个加工的输入输出数据流必须与其子图的输入输出数据流在数量上和名字上相同。父图的一个输入(或输出)数据流对应于子图中几个输入(或输出)数据流,而子图中组成的这些数据流的数据项全体正好是父图中的这一个数据流。

2. 试题二

阅读下列说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 【说明】

某房屋租赁公司拟开发一个管理系统用于管理其持有的房屋、租客及员工信息。请根据下述需求描述完成系统的数据库设计。

【需求描述】

1.公司拥有多幢公寓楼,每幢公寓楼有唯一的楼编号和地址。每幢公寓楼中有多套公寓,每套公寓在楼内有唯一的编号(不同公寓楼内的公寓号可相同〉。系统需记录每套公寓的卧室数和卫生间数。

2.员工和租客在系统中有唯一的编号(员工编号和租客编号)。

3.对于每个租客,系统需记录姓名、多个联系电话、一个银行账号(方便自动扣房租)、一个紧急联系人的姓名及联系电话。

4.系统需记录每个员工的姓名、一个联系电话和月工资。员工类别可以是经理或维修工,也可兼任。每个经理可以管理多幢公寓楼。每幢公寓楼必须由一个经理管理。系统需记录每个维修工的业务技能,如:水暖维修、电工、木工等。

5. 租客租赁公寓必须和公司签订租赁合同。一份租赁合同通常由一个或多个租客(合租)与该公寓楼的经理签订,一个租客也可租赁多套公寓。合同内容应包含签订日期、开始时间、租期、押金和月租金。

【概念模型设计】

根据需求阶段收集的信息,设计的实体联系图(不完整)如图2-1所示。 【逻辑结构设计】

根据概念摸型设计阶段完成的实体联系图,得出如下关系模式(不完整): 联系电话(电话号码,租客编号)

租客(租客编号,姓名,银行账号,联系人姓名,联系人电话) 员工(员工编号,姓名,联系电话,类别,月工资, (a) ) 公寓楼( (b) ,地址,经理编号)

公寓(楼编号,公寓号,卧室数,卫生间数〉

合同(合同编号,租客编号,楼编号,公寓号,经理编号,签订日期,起始日期,租期, (c) ,押金)

1. 问题:2.1 补充图2-1中的“签约”联系所关联的实体及联系类型。 该问题分值: 4.33333333333333 答案:

2. 问题:2.2 补充逻辑结构设计中的(a)、(b)、(c)三处空缺。 该问题分值: 4.33333333333333 答案:(a)业务技能 (b)楼编号 (c)月租金

3. 问题:2.3 在租期内,公寓内设施如出现问题,租客可在系统中进行故障登记,填写故障描述,每项故障由系统自动生成唯一的故障编号,由公司派维修工进行故障维修,系统需记录每次维修的维修日期和维修内容。请根据此需求,对图2-1进行补充,并将所补充的ER图内容转换为一个关系模式,请给出该关系模式。

该问题分值: 4.33333333333333 答案:

新增维修关系,维修工维修公寓,关系模式为维修情况

维修情况(故障编号,员工编号,楼编号,公寓号,维修日期,维修内容)

3. 试题三

阅读下列系统设计说明,回答问题1至问题3,将解答填入答题纸的对应栏内。 【说明】

某玩具公司正在开发一套电动玩具在线销售系统,用于向注册会员提供端对端的玩具 定制和销售服务。在系统设计阶段,\创建新订单 (New Order)\的设计用例详细描述如表 3-1 所示,候选设计类分类如表 3-2 所示,并根据该用例设计出部分类图如图3-1所示。

表 3-1 创建新订单 (NewOrder) 设计用例

在订单处理的过程中,会员可以点击“取消订单\取消该订单。如果支付失败,该订单将被标记为挂起状态,可后续重新支付,如果挂起超时30分钟未支付,系统将自动取消该订单。订单支付成功后,系统判断订单类型:

(1)对于常规订单,标记为备货状态,订单信息发送到货运部,完成打包后交付快递发货;

(2)对于定制订单,会自动进入定制状态,定制完成后交付快递发货。会员在系统中点击”收货\按钮变为收货状态,结束整个订单的处理流程。根据订单处理过程所设计的状态图如图3-2所示。

1. 问题:3.1 根据表3-1中所标记的候选设计类,请按照其类别将编号 C1~C12 分别填入表 3-2 中的(a)、(b)和(c)处。

该问题分值: 4.33333333333333 答案:(a):C4、C5、C7、C8、C10、C11 (b):C3 (c):C1、C2、C6、C9、C12 一、实体类

实体类是用于对必须存储的信息和相关行为建模的类。实体对象(实体类的实例)用于保存和更新一些现象的有关信息,例如:事件、人员或者一些现实生活中的对象。实体类通常都是永久性的,它们所具有的属性和关系是长期需要的,有时甚至在系统的整个生存期都需要。

二、边界类

边界类是系统内部与系统外部的业务主角之间进行交互建模的类。边界类依赖于系统外部的环境,比如业务主角的操作习惯、外部的条件的限制等。它或者是系统为业务主角操作提供的一个GUI,或者系统与其他的系统之间进行一个交互的接口,所以当外部的GUI变化时,或者是通信协议有变化时,只需要修改边界类就可以了,不用再去修改控制类和实体类。业务主角通过它来与控制对象交互,实现用例的任务。

边界类调用用例内的控制类对象,进行相关的操作。 一个系统可能会有多种边界类:

用户界面类 - 帮助与系统用户进行通信的类 系统接口类 - 帮助与其他系统进行通信的类

设备接口类 - 为用来监测外部事件的设备(如传感器)提供接口的类 三、控制类

控制类用于对一个或几个用例所特有的控制行为进行建模,它描述的用例的业务逻辑的实现,控制类的设计与用例实现有着很大的关系。在有些情况下,一个用例可能对应多个控制类对象,或在一个控制类对象中对应着对个用例。它们之间没有固定的对应关系,而是根据具体情况进行分析判断,控制类有效将业务逻辑独立于实体数据和边界控制,专注于处理业务逻辑,控制类会将特有的操作和实体类分离,者有利于实体类的统一化和提高复用性。

当业务主角通过边界类来执行用例的时候,产生一个控制类对象,在用例被执行完后,控制类对象会被销毁。

控制类的特点:独立于环境、和用例的实现关联、使用关联实体类或操作实体类对象、 专注于业务逻辑的实现。

当然如果用例的逻辑较为简单,可以直接利用边界类来操作实体类,而不必再使用控制类。或者用例的逻辑较为固定,业务逻辑固定不会改变。也可以直接在边界类实现该逻辑。

2. 问题:3.2 根据创建新订单的用例描述,请给出图3-1中X1~X4处对应类的名称。 该问题分值: 4.33333333333333