5.活动图
(1)基本符号
和状态图类似,初态用实心表示,终态用环形表示,圆角矩形代表活动,菱形代表分支,横线黑线代表并发。
可以参考这张图,更为直观
(2)实战演练
例题:下面的文字描述了某大学新生报到的过程:
新生首先要填一张新生注册表单。如果填写不正确,则在别人的帮助下重新填写,直至填写正确,然后进行注册。注册成功之后,要进行开学典礼,同时在新生选课系统中注册,然后交齐第一个学期的学费。 画出活动图。
6.用例图
用例图由三个基本元素和四个关系构成。
三个元素:参与者、用例、容器
四个关系:关联、泛化、包含、扩展
(1)基本符号
①三个元素
②四个关系
Ⅰ 关联
适用于参与者和用例之间,通常由参与者指向用例。
用单向实箭头表示
Ⅱ 泛化
适用于于用例与用例之间或参与者与参与者之间。它和面向对象中的继承关系类似,子用例继承父用例的所有功能。
用空心三角箭头表示
Ⅲ 包含
适用于用例和用例直接,由复杂用例分解出简单用例
用虚线箭头表示
Ⅳ 扩展
适用于用例与用例直接,对基础用例的功能扩展
用虚线箭头表示
(2)实战演练1
例题:在火车票预订系统中,客户可以进行购买车票、退订车票、查询余票和查询列车时刻四个操作。不管是购买车票还是退订车票,用户都必须先进行登录系统操作。其中查询列车时刻主要包括按站站查询和按车次查询两种方式。如果在登录系统的过程中忘记密码,则还可使用找回密码功能。画出用例图。
(3)实战演练2
例题:系统拥有注册功能,顾客注册后进行登录,才能在系统中购买商品;顾客可以通过系统浏览商品,查看商品的详细信息,购买自己喜欢的商品;顾客付费方式要多样化,既可以通过银行的在线支付功能付款,也可通过汇款方式付款;系统拥有商品的促销功能,对于某些系统指定的商品或用户购买的商品金额超过一定数量时,在顾客结账时给予优惠;
用例图顾客登录后,可以使用留言功能对商品或服务留言评价;
系统的管理员可以使用留言功能对顾客提出的疑问做出解答,还可以管理注册的用户;录入员能够更新商品信息,包括增加新商品和对现有商品信息的更新;系统允许多人同时在线,进行商品的浏览和购买操作。
7.类图
(1)构成要素
类图由类的名称、字段和属性、方法,三部分构成。
其中“+” 表示public;“-“ 表示private;”#"表示protected
比如
第一层“动物”是类的名称;
第二层“+有生命”是动物的属性;
第三层“+新陈代谢+繁殖”是动物具有的方法。
(2)基本关系
①继承
鸟属于动物,可以继承动物属性
表示方法:实线+空心箭头
②实现
飞翔实现了“飞行”方法
表示方法:虚线+空心箭头
③关联
企鹅的生活和气候息息相关
表示方法:实线箭头
④依赖
动物需要水和氧气才能生存
表示方法:虚线箭头
⑤聚合(包含)
一个雁群中有很多大雁,即包含关系
表示方法:空心菱形 + 实线箭头
⑥组合(拥有)
鸟和它的翅膀体现了部分和整体的关系,即组合关系
表示方法:实心菱形 + 实线箭头
(3)实战演练
根据以下描述,画出相应的UML类图
神舟六号飞船是神州飞船系列的一种,它由轨道舱、返回舱、推进舱和逃逸救生塔等组成。
航天员可以在返回舱内驾驶飞船,轨道舱是航天员工作和休息的场所。在紧急的情况下,可以利用逃逸救生塔逃生。
在飞船两侧有多个太阳能电池翼,可以为飞船提供电能
8.程序图(顺序图/程序控制流图)
(1)基本概念
程序图可以将程序流程图,N-S图,PAD图映射到图形中。
注意:
一个或多个顺序语句可以映射为程序图的一个节点,用带标识的圆表示。
一个处理框或判定框可以映射为一个节点
程序控制流向用方向箭头表示,且一条边必须终止于一个节点(该节点可以不代表任何含义)
比如下图,可以将2,3分为两个圆表示,也可以合在一起
(2)计算环形复杂度
环形复杂度V(G)=E-N+2,其中,E是程序图中边数,N是结点数
上图中V(G)=11-9+2=4
有人可能要问,如果将图中2、3两个节点和4、5两个节点分开结果依然正确吗?
可以自己试试,不影响复杂度,V(G)=13-11+2=4
9.常见软件过程模型的特点
模型名称 | 技术特点 | 适用范围 |
瀑布模型 | 简单,分阶段,阶段间存在因果关系,各个阶段完成后都有评审,允许反馈,不支持,用户参与,要求预先确定需求 | 需求明确且不易改变的软件系统,专业 |
快速原型模型 | 不要求需求预先完备定义,支持用户参与,支持需求的渐进式完善和确认,能够适应用户需求的变化 | 需求复杂、难以确定、动态变化的软件系统,小白 |
增量模型 | 软件产品是被增量式地一块块开发的,允许开发活动并行和重叠 | 软件开放,逐渐增加功能的软件系统 |
迭代模型 | 不要求一次性地开发出完整的软件系统,将软件开发视为一个逐步获取用广需求、完善软件产品的过程 | 需求难以确定、不断变更的软件系统 |
螺旋模型 | 结合瀑布模型、快速原型模型和迭代模型的思想,并引进了风险分析活动 | 需求难以获取和确定、软件开发风险较大的软件系统 |
RUP | 可改造、扩展和剪裁:可以对它进行设计、开发、维护和发布;强调迭代开发 | 复杂和需求难以获取和确定的软件系统;软件开发项目组拥有丰富的软件开发和管理经验 |
(1)实战演练
例1:要开发某个突破性的产品,规模很大,所需的开发技术先进,风险较大,且市面上尚未有类似产品,用户尚未对其形成完整的预期,团队人员充足。
答案:螺旋模型
例2:要开发的系统类似于某个团队之前已经做过的某个项目,只是规模更大复杂性高一点,需求已经有用户写成文档。
答案:瀑布模型
例3:辅导员张老师 为了方便管理学生,他委托学生小明帮助他开发一个学生管理系统,用来管理他所带的班级的学生信息,该系统仅供张老师一个人使用,系统功能不是很复杂。张老师对自己需要的系统功能有了明确的认识,并且他本身也对软件开发有一定程度的了解,与小明的沟通过程非常的顺利。在这种情况下,如果你是小明,你会选用哪种过程模型?
答案:瀑布模型
例4:张扬是某大学软件技术专业的学生,在寒假中,他为他的邻居开发了一个小型的超市管理系统。他的邻居从来不懂软件开发,也不知道超市管理系统应该是什么样的。那么你建议张扬采用哪种过程模型呢 ?
答案:快速原型模型
例5:假设要求你开发一个软件,该软件的功能是读入的浮点数开平方,所得到的结果应该精确到小数点后4位。一旦实现并测试完之后,该产品将被抛弃。你打算选用哪种软件生命周期模型?请说明你做出选择的理由。
答案:瀑布模型
对这个软件的需求很明确,实现开平方功能的算法也很熟悉,因此,无须通过原型来分析需求也无需用原型来验证设计方案。此外,一旦实现并测试完之后,该产品将被抛弃,因此也无须使用有助于提高软件可维护性的增量模型或带风险分析的螺旋模型来开发该软件。
二、知识点汇总
1.软件危机
(1)概念
软件危机是指在计算机软件开发和维护时所遇到的一系列问题。
(2)主要表现
如何开发软件以满足对软件日益增长的需求;
如何维护数量不断增长的已有软件。
软件成本在计算机系统成本中所占的比例逐年上升
用户对已完成的软件系统不满意的现象经常发生;
(3)软件危机产生的原因:
软件规模庞大,给软件的维护带来困难。
软件一般使用3~5年,在这段时间内很可能因为环境的改变、硬件的改变、技术方式的改变、需求的改变,需要及时的维护。
软件开发技术的落后。
软件开发人员忽视需求分析、维护阶段的重要性也是造成软件危机的原本。
2.结构化设计方法的步骤
首先研究、分析数据流图
然后根据数据流图决定问题的类型
由数据流图推导出系统的初始结构图
利用启发性原则来改进系统的初始结构图,直到符合要求的结构图为止
修改和补充数据字典
制定测试计划
3.软件设计的过程
软件设计是把许多事物和问题抽象起来,并且抽象它们不同层次和角度,是将需求转变为软件陈述的过程,是迭代的过程。
软件设计,要根据需求规格说明书,对整个设计过程进行计划,然后实施具体的设计过程,即“先整体,再局部”,也是不断迭代和精化的过程。
然后需要对生成的设计规格说明书进行评审,启动 质量评价的标准,若未通过评审,需重新修改设计,直至评审通过,确定最后定型的过程本身。进入后续阶段,完成软件设计过程。
4.黑盒测试法
黑盒测试法把程序看成一个黑盒子,完全不考虑程序的内部结构和处理过程
它只检查程序功能是否能按照规格说明书的规定正常使用
程序是否能适当地接收输入数据
产生正确地输出信息
5.软件设计的原则
模块化
抽象化与逐步求精
信息隐藏与局部化
模块独立
6.软件测试的目的
软件测试是为了发现错误而执行程序的过程;
测试是程序的执行过程,目的在于发现错误;
软件测试中需要数据,即为测试而精心设计的测试用例,利用测试用例去运行程序,帮助发现程序错误;
一个好的测试用例在于能发现至今未发现的错误;
一个成功的测试是发现了至今未发现的错误的测试。
三、题目练习
1.设计测试用例
(1)例题1
下图显示了某程序的逻辑结构。试为它设计足够的测试用例,分别实现对程序的:判定覆盖、条件覆盖、条件组合覆盖
答案:
(2)例题2
某三角形程序的功能为:读入代表三角形边长的3个整数,判断它们能否组成三角形。如果能够,则输出三角形是等边、等腰或任意三角形的识别信息。试为此程序设计一组测试用例。(本例将先用黑盒法设计测试用例,然后用白盒法进行检验与补充)
答案:
第一步:根据题干,在黑盒法中首先可用等价分类法划分输入的等价类,然后用边界值分析法和猜错法作补充。
边界值法:2数之和等于第3数
猜错法:输入3个零、输入3个负数
第二步:提出一组初步的测试用例,
第三步:用白盒法验证第三步产生的测试用例的充分性。结果表明,上表中的前8个测试用例,已能满足对被测程序图的完全覆盖,不需要再补充其他的测试用例。
(3)例题3
设有一个档案管理系统,要求用户输入以年月表示的日期。假设日期限定在1990年1月~2003年12月,并规定日期由6位数字字符组成,前4位表示年,后2位表示月。现用等价类划分法设计测试用例,来测试程序的“日期检查功能”。
答案:
第一步:划分等价类并编号,下表等价类划分的结果
输入等价类 | 有效等价类 | 无效等价类 |
日期的类型及长度 | ①6位数字字符 | ②有非数字字符 ③少于6位数字字符 ④多于6位数字字符 |
年份范围 | ⑤在1990~2049之间 | ⑥小于1990 ⑦大于2049 |
月份范围 | ⑧在01~12之间 | ⑨等于00 ⑩大于12 |
第二步:设计测试用例,以便覆盖所有的有效等价类在表中列出了3个有效等价类,编号分别为①、⑤、⑧,设计的测试用例如下:
测试数据 | 期望结果 | 覆盖的有效等价类 |
202211 | 输入有效 | ①、⑤、⑧ |
202301 | 输入有效 | ①、⑤、⑧ |
203512 | 输入有效 | ①、⑤、⑧ |
第三步:为每一个无效等价类设计一个测试用例,设计结果如下:
测试数据 | 期望结果 | 覆盖的无效等价类 |
95June | 无效输入 | ② |
20036 | 无效输入 | ③ |
2001006 | 无效输入 | ④ |
198912 | 无效输入 | ⑥ |
200401 | 无效输入 | ⑦ |
200100 | 无效输入 | ⑨ |
200113 | 无效输入 | ⑩ |
(4)例题4
某城市的电话号码由3部分组成,这3部分的名称和内容为:
地区码:空白或3位数字;
前 缀:非‘0’或‘1’开头的3位数字;
后 缀:4位数字。
假定被测程序能接受一切符合上述规定的电话号码,拒绝所有不符合规定的号码,试用等价分类法设计它的测试用例。
答案:
第一步:划分等价类。
下表列出了划分的结果,包括4个有效等价类,11个无效等价类。在每一等价类之后均加有编号,以便识别
第二步:确定测试用例。
2.画程序流程图,计算复杂度
(1)例题1
已知有一段代码实现了 “输出ABC三个数中的最大值”,要求完成下列问题:
(1)画出代码的流程图
(2)根据该程序流程图画出该程序的流图
(3)计算该流图的环形复杂度
答案:
(1)流程图:
(2)程序图:
(3)
环形复杂度:
V(G) = 边数 - 节点数 + 2 = 9 - 7 + 2 = 4