23-24-2-软件工程-期末
目录
一、填空题(10题,每题1分,共10分)
-
敏捷开发中,个体与交互重于过程与工具,可工作的软件重于面面俱到的 ,客户合作重于合同谈判,响应变化重于遵循计划。
-
软件需求分析阶段需要编制两份说明文档,分别是用户需求说明书和 。
-
用例模型由四个部分构成:用例图、用例说明、系统顺序图和 。
-
软件的概要设计主要进行两项设计活动,分别是 和数据设计。
-
面向对象设计中交互图的主要任务是确定 并为其分配功能。
-
源程序文档化主要体现在为代码进行 和功能性注释。
-
测试用例由测试的 和 构成。
-
开发计划由以下三个部分构成:, 和责任人。
二、判断题(10题,每题1分,共10分)
-
软件工程起源于解决程序设计不能解决的问题。
-
极限编程的功能需求是通过用例的方式进行描述。
-
需求调研过程中需要了解当前业务系统是如何处理业务请求的细节。
-
UML 交互图中对象 A 给对象 B 发送了一条同步消息 M,则对象 A 具有功能 M。
答案 / 解析
应是对象 B 具有处理消息 M 的功能。
- UML 交互图中一个对象实例不可以给自己发送消息。
答案 / 解析
对象通过自发一条消息表示对自身或对本对象其他操作的调用,这种消息称为自返消息。
-
软件的概要设计的包括系统的界面设计和数据设计。
-
模块的内聚描述的是类之间关系的紧密程度。
答案 / 解析
内聚是模块功能强度的度量,用于表示一个模块内部各元素彼此结合的紧密程度。耦合是模块之间连接紧密程度的度量。
-
系统的确认测试表示要通过基于需求分析规格说明书的测试用例。
-
控制器层的对象应该实现系统事件的请求逻辑。
-
软件交付用户之后就不再需要进行软件测试活动了。
三、选择题(单选题每题1分,多选题每题2分,共10分)
- 本学期的课程作业采用的是以下哪一项生命周期模型 ( )
- 下面哪一项不属于操作契约中后置条件所需规定的内容 ( )
- 下面哪一项属于领域模型的范畴 ( )
- 面向对象的概要设计需要用到以下哪几项 UML 的图 ( )
答案 / 解析
面向对象概要设计的主要工作就是,基于面向对象需求分析中产生的用例(用例图)、领域模型(类图)、系统顺序图(顺序图)以及操作契约,进行系统动态结构设计(产生交互图)和系统静态结构设计(产生类图)。
- 以下哪种情况违反了单一职责原则? ( )
- 面向对象的设计原则中哪一项描述的是模块的耦合性?( )
答案 / 解析
迪米特法则即最少知识原则,强调一个对象应当尽可能少的了解其他对象,即减少模块之间的关系。该表述强调低耦合。
单一职责原则强调一个类应该有且只有一个引起它变化的原因。该表述符合功能内聚的特征。
开闭原则强调对扩展开放,对修改封闭;组合/聚合复用原则强调组合优于继承。二者均强调可复用性和可维护性。
- 以下哪种情况最有可能违反迪米特法则?( )
- 某程序使用等价类划分构造测试用例,其中有效等价类有3个,无效等价类有4个,请问最少需要设计多少组测试数据 ( )
- 以下哪一项方法可以有效降低测试用例的数量 ( )
答案 / 解析
因果图:考虑输入条件之间的制约关系,去除不可能输入条件组合对应的测试用例。该技术可减少有限多个测试用例。
基本路径测试:通过程序控制流图选取基本路径设计测试用例。该技术的测试用例个数是固定的,应等于对应程序段的环路复杂度。
边界值分析:选取等价类中的边界值作为测试用例。该技术提高了测试用例的效率,但反而增加了测试用例的个数。
等价类划分:通过划分等价类、编号、覆盖等步骤,将测试用例从无穷多个可能的取值组合转换为有限多个等价类的排列组合。该技术将测试用例个数从无穷多个变为有限多个,极大地减少了测试用例的个数。该技术是最直接、最根本地减少测试用例数量的方法。
四、简答题(共5题,每题3分,共计15分)
- 请描述软件工程产生的历史背景及作用。
答案 / 解析
背景:20世纪60年代后,随着计算机软件应用领域增多,软件规模不断扩大,软件系统功能多,逻辑复杂,不断扩充,从而导致许多系统开发出现了不良的后果。
作用:运用工程化的原则和方法,组织软件开发解决软件危机。
-
请给出除了极限编程之外你认为最适合课程作业的1种生命周期模型,并给出理由。
-
请给出领域模型的作用,并描述业务流程使用哪一种UML图形表示。
-
软件的概要设计有哪几个主要活动?课程作业2要求完成哪几个用例的设计?
答案 / 解析
- 系统结构设计
- 处理方式设计
- 数据设计
- 可靠性设计
- 界面设计
- 分别从使用者和开发者的角度描述软件测试的目的。
答案 / 解析
使用者:通过软件测试暴露软件中的错误的缺陷,以考虑是否可接受该软件产品。
开发者:希望测试成为表明软件产品中不存在错误,验证该软件已正确地实现了用户的要求,确立人们对软件质量的信心。
五、应用题(2题,共25分)
1(10分)
已知某程序代码如下:
def discount(role, price, date):
if role == 1:
return price * 0.8
elif role == 2 and date == '0910':
return price * 0.8
elif price >= 200:
return price * 0.85
elif role == 2:
return price * 0.9
return price
要求:
- 给出程序控制流图,注意复合条件的分支结构。(4分)
- 用基本路径法计算控制流图的环路复杂度。(4分)
- 给出必须覆盖的基本路径集。(2分)
2(15分)
黑盒测试用例,已知条件如下:
| 房间号 | 初始温度 | 模式 |
| R1 | 32 | 制冷 |
| R2 | 28 | |
| R3 | 28 | |
| R4 | 35 | |
| 计费费率 | 1元/1度(温度) | |
| 风速 | H 高速 | 1度/1分钟 |
| M 中速(缺省) | 1度/2分钟 | |
| L 低速 | 1度/3分钟 | |
现有房间4个:R1, R2, R3, R4;服务资源只有3个,需要进行调度:优先级调度和时间片调度相结合,如果等待队列与服务队列的优先级相同时启动时间片:每2分钟调度一次,规定服务队列中序号小的首先被调度出去。请填写下表中10分钟(每一行代表1分钟间隔)每个房间的数据以及服务队列和等待队列的信息。
CT=当前室温;TT=目标温度;FS=风速;Fee=费用;
O=开机;H=高速风;C=关机;
数字=表示目标温度。
| R1 | R2 | R3 | R4 | R1 | R2 | R3 | R4 | 服务队列 | 等待 | ||||||||||||||
| CT | TT | FS | Fee | CT | TT | FS | Fee | CT | TT | FS | Fee | CT | TT | FS | Fee | 以下单元格填入房间号 | |||||||
| O | |||||||||||||||||||||||
| 18 | O | O | |||||||||||||||||||||
| O,H | |||||||||||||||||||||||
| 19 | |||||||||||||||||||||||
| 22 | |||||||||||||||||||||||
| H | |||||||||||||||||||||||
| H | |||||||||||||||||||||||
| H | O | C | |||||||||||||||||||||
| 22 | C | ||||||||||||||||||||||
| C | C | ||||||||||||||||||||||
六、综合题(5个问题,总共30分)
学生和老师在校医院大厅使用自助挂号机进行挂号的流程如下:
- 将一卡通放置在挂号机的识别器上;
- 选择挂号;
- 选择问诊的科室(假定科室分为内科、外科、耳鼻喉科等);
- 扫描二维码进行支付;
- 获取挂号单;
- 完成一次挂号。
挂号单具有以下信息:病人姓名,科室,挂号时间,挂号的队列号。
- 请问为了完成一次挂号,病人与系统之间一共进行了多少次交互?(3分)
- 挂号单对象实例在哪一个环节被创建?(3分)
- 挂号的队列号请问在上述流程中哪一个步骤中产生?(5分)
- 请给出第2和第3条指令的操作契约,请你给出该消息对应的交互图。(7分)
- 如果系统的架构有 GUI、控制器层和应用逻辑层,请给出第3条指令对应的交互图:确定控制对象以及应用逻辑层的软件对象。(12分)