行单独的测试。由于每个模块都有清晰定义的功能,所以通常比较容易设计相应的测试方案,以检验每个模块的正确性。 集成测试:
在单元测试完成后,要考虑将模块集成为系统的过程中可能出现的问题,例如,模块之间的通信和协调问题,所以在单元测试结束之后还要进行集成测试。这个步骤着重测试模块间的接口,子功能的组合是否达到了预期要求的功能,全程数据结构是否有问题等。 白盒测试技术(逻辑覆盖、基本路经测试)
白盒测试时将程序看作是一个透明的盒子,也就是说测试人员完全了解程序的内部结构和处理过程。所以测试时按照程序内部的逻辑测试程序、检验程序中的每条通路是否都能按预定的要求正确工作。白盒测试又称为结构测试。
语句覆盖就是设计足够的调试用例,使得程序中的每个语句至少执行一次。 判定覆盖就是设计足够的测试用例,使得程序中每个判定的取“真”分支和取“假”分支至少都执行一次,判定覆盖又称分支覆盖
条件覆盖就是设计足够的测试用例,使得程序判定中的每个条件能获得各种可能的结果。 判定/条件覆盖就是设计足够的测试用例,使得判定中的每个条件都取到各种可能的值,而且每个判定表达式也都取到各种可能的结果。 条件组合覆盖就是设计足够的测试用例,使得每个判定中的条件的各种可能组合都至少出现一次。
基本路经测试:
黑盒测试技术(等价划分)
黑盒测试时完全不考虑程序内部的结构和处理过程,只按照规格说明书的规定来检查程序是否符合它的功能要求。黑盒测试是在程序接口进行的测试,又称为功能测试。 1、黑盒测试检查的主要方面有: 程序的功能是否正确或完善;
数据的输入能否正确接收,输出是否正确;
是否能保证外部信息(如数据文件)的完整性等。 用黑盒法设计测试用例时,必须用所有可能的输入数据来检查程序是否都能产生正确的输出 2、等价类划分
等价类的划分在很大程度上依靠的是测试人员的经验,下面给出几条基本原则: (1)如果输入条件规定了取值范围,则可划分出一个有效的等价类(输入值在此范围内)和两个无效的等价类(输入值小于最小值、输入值大于最大值)。
(2)如果输入条件规定了输入数据的个数,则可相应地划分出一个有效的等价类(输入数据的个数等于给定的个数要求)和两个无效的等价类(输入数据的个数少于给定的个数要求、输入数据的个数多于给定的个数要求)。
(3)如果输入条件规定了输入数据的一组可能的值,而且程序对这组可能的值做相同的处理,则可将这组可能的值划分为一个有效的等价类,而这些值以外的值划分成无效的等价类。 (4)如果输入条件规定了输入数据的一组可能的值,但是程序对不同的输入值做不同的处理,则每个输入值是一个有效的等价类,此外还有一个无效的等价类(所有不允许值的集合)。 (5)如果输入条件规定了输入数据必须遵循的规则,则可以划分一个有效的等价类(符合规则)和若干个无效的等价类(从各种角度违反规则)。
维护(改正性维护、适应性维护、完善性维护、预防性维护)
决定软件可维护性因素(可理解性、可测试性、可修改性、可移植性、可重用性)
面向对象方法学优点:1、与人类习惯的思维方法一致2、稳定性好3、可重用性好4、较易
开发大型软件产品5、可维护性好
对象模型1、关联2、聚集3、泛化4、依赖和细化
贰 软件工程
软件危机
1、软件危机是指在计算机软件的开发和维护过程中所遇到的一系列严重问题。(熟记)
2、了解软件危机主要的一些典型表现。(P2) 3、出现软件危机的原因:
4、消除软件危机的途径:首先,我们要对计算机软件有一个正确的认识;更重要的是,必须充分认识到软件开发不是某种个体劳动的神秘技巧,而应该是一种组织良好、管理严格、各类人员协同配合、共同完成的工程项目;最后,应该开发和使用更好的软件工具。
总之,为了解决软件危机,既要有技术措施(方法和工具),又要有必要的组织管理措施。
软件工程
1、软件工程:采用工程的概念、原理、技术和方法来开发和维护软件,把经过时间考验而证明正确的管理技术和当前能够得到的最好的技术方法结合起来,以经济地开发出高质量的软件并有效地维护它。(熟记) 2、了解软件工程的本质特征:
1)、软件工程关注于大型程序的构造 2)、软件工程的中心课题是控制复杂性 3)、软件经常变化 4)、开发软件的效率非常重要 5)、和谐的合作是开发软件的关键 6)、软件必须有效地支持它的用户 7)、在软件工程的领域中通常由具有一种文化背景的人替具有另一种文化背景的人创造产品
3、缺乏应用领域地相关知识,是软件开发项目出现问题的常见原因。 4、软件工程的基本原理: 1)、用分阶段的生命周期计划严格管理 2)、坚持进行阶段审评 3)、实行严格的产品控制 4)、采用现代程序设计技术 5)、结果应能清楚地审查 6)、开发小组的人员应该少而精 7)、承认不断改进软件工程实践的必要性 5、方法学(范型):在软件生命周期全过程中使用的一整套技术方法的集合。 6、软件工程方法学3要素:方法、工具和过程。
7、目前使用得最广泛的软件工程方法学,分别是传统方法学和面向对象方法学 8、传统方法学也成为生命周期方法学或结构化范型。 9、面向对象方法学具有的4个要点。(P10)
软件生命周期
1、概括地说,软件生命周期由软件定义、软件开发和运行维护(也称为软件维护)3个时期组成,每个时期又进一步划分成若干个阶段。 2、软件定义时期的任务
3、软件定义时期通常进一步划分成3个阶段:问题定义、可行性研究、需求分析
4、维护时期的主要任务是使软件持久地满足用户的需要。
5、软件开发时期通常分成4个阶段:总体设计、详细设计、编码和单元测试、综合测试。前两个阶段又称为系统设计,后两个阶段又称为系统实现。
6、软件生命周期每个阶段的基本任务:问题定义、可行性研究、需求分析、总体设计、详细设计、编码和单元测试、综合测试。
软件工程
生命周期模型(过程模型):瀑布模型、快速原型模型、增量模型、螺旋模型、喷泉模型。
(对各种模型要了解)
小结(熟读,对本章系统地了解)
可行性分析
可行性分析的目的:用最小的代价在尽可能短的时间内确定问题是否能够解决。
可行性研究的任务
研究解法的可行性的三个方面:技术可行性、经济可行性、操作可行性。 可行性研究最根本的任务:对以后的行动方针提出建议。 可行性研究需要的时间长短取决于工程的规模。
可行性研究过程
复查系统规模和目标 研究目前正在试用的系统 导出新系统的高层逻辑模型 进一步定义问题
导出和评价供选择的解法 推荐行动方针 草拟开发计划
书写文档提交审查
系统流程图
1、系统流程图:概括地描绘物理系统的工具。 2、系统流程图的基本思想:用图形符号以黑盒子形式描绘组系统的每个部件(程序、文档、数据库、人工过程等)。 3、P39符号
4、系统流程图的习惯画法:使信息在图中从顶向下或从左向右流动。 5、面对复杂的系统时,一个比较好的方法时分层次地描绘这个系统。
数据流图
数据流图(DFD):一种图形化技术,它描绘信息流和数据从输入移动到输出的过程中所经受的变换。
数据流图的四种基本符号P41
数据存储(静止状态)和数据流(运动)都是数据。 数据流图的基本要点是描绘“做什么”,而不是考虑“怎么做”。
星号(*)是数据流之间的“与”关系;加号(+)表示“或”关系;⊕号表示只能从中选一个(互斥关系)。
画数据流图的基本目的是利用它作为交流信息的工具。
数据字典
数据字典应由对下列4类元素的定义组成:数据流、数据流分量(即数据元素)、数据存储、处理。
由数据元素组成数据的方式的三种基本类型:顺序、选择、重复。+可选 用以下符号描述由数据元素组成数据的关系:=意思是等价于(或定义为)、+意思是和(即连接两个分量)、[ }意思是或(通常用“|”号隔开供选择的分量)、{ }意思是重复、( )意思是可选。
数据字典最重要的用途是作为分析阶段的工具。
成本/效益分析
成本/效益分析的目的:从经济角度分析开发一个特定的新系统是否划算,从而帮助客户组织的负责人正确地作出是否投资于这项开发工程的决定。 软件开发成本:主要表现为人力消耗。
成本估算技术:代码行技术、任务分解技术、自动估计成本技术。 货币的时间价值:用利率的形式。
假设年利率为i,如果现在存入P元,则n年后的价值:F=P(1+i)^n 衡量一项开发工程的价值:投资回收期。 纯收入
投资回收率
小结
三 需求分析
需求分析是软件定义时期的最后一个阶段。
基本任务:准确地回答“系统必须做什么?”这个问题。 用于需求分析的结构化分析方法必须遵守下述准则: (1)、必须理解并描述问题的信息域,根据这条准则应该应该建立数据模型。E-R图 (2)、必须定义软件应完成的功能,这条准则要求建立功能模型。数据流图 (3)、必须描述作为外部事件结果的软件行为,这条准则要求建立行为模型。状态图 (4)、必须对描述信息、功能和行为的模型进行分解,用层次的方式展开细节。
需求分析的任务
对软件系统的综合要求:功能需求、性能需求、可靠性和可用性需求、出错处理需求、接口需求、约束、逆向需求、将来可能提出的要求。 需求分析的任务:确定对系统的综合要求 分析系统的数据要求 导出系统的逻辑模型 修正系统开发计划
与用户沟通获取需求的方法
访谈、面向数据流自顶向下求精、简易地应用规格说明技术,快速建立软件原型。 结构化分析方法就是面向数据流自顶向下求精进行需求分析的方法。 快速建立软件原型是最准确、最有效、最强大的需求分析技术。
分析建模与规格说明
需求分析过程应建立3种模型:数据模型、功能模型、行为模型。 数据流图是建立功能模型的基础。 状态转换图是行为建模的基础。
实体-联系图(E-R)