程序设计与软件开发基础六_第1页
程序设计与软件开发基础六_第2页
程序设计与软件开发基础六_第3页
程序设计与软件开发基础六_第4页
程序设计与软件开发基础六_第5页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、第32讲 程序设计与软件开发基础(六)教学目标及基本要求:理解结构化设计方法,能利用该方法提供的常用工具解决实际问题,掌握测试与调试的概念,了解白盒测试与黑盒测试的概念,能进行简单的测试用例设计和实施,了解静态调试与动态调试。教学重点:测试和调试的基本概念,白盒测试与黑盒测试。 教学难点:面向数据流的设计方法,白盒测试与黑盒测试。教学内容:1结构化设计方法2软件测试及调试教学时间:1学时主要内容: 结构化设计方法1软件设计的基本概念(1)软件设计的基础v 概念软件设计是软件工程的重要阶段,是一个把软件需求转换为软件表示的过程。v 基本目标软件设计的基本目标是用比较抽象概括的方式确定目标系统如何

2、完成预定的任务,即软件设计是确定系统的物理模型。 v 步骤从工程管理角度来看,软件设计分两步完成:概要设计和详细设计。 Ø 概要设计(又称结构设计) :将软件需求转化为软件体系结构、确定系统级接口、全局数据结构或数据库模式 。Ø 详细设计:确立每个模块的实现算法和局部数据结构,用适当方法表示算法和数据结构的细节。 (2)软件设计的基本原则 抽象:是一种思维工具,就是把事物本质的共同特性提取出来而不考虑其他细节。 模块化:是指把一个待开发的软件分解成若干小的简单的部分。 信息隐蔽:是指在一个模块内包含的信息,对于不需要这些信息的其他模块来说是不能访问的。 模块独立性:是指每个

3、模块只写成系统要求的独立的子功能,并且与其他模块的联系最少且接口简单。模块的独立程度是评价设计好坏的重要度量标准。衡量软件的模块独立性使用耦合性和内聚性两个定性的度量标准。一个优秀的软件设计应尽量做到高内聚、低耦合。2概要设计(1)概要设计的任务 设计软件系统结构:在需求分析阶段,已经把系统分解成层次结构,而在概要设计阶段,需要进一步分解,划分为模块以及模块的层次结构。 数据结构及数据库设计:数据设计是实现需求定义和规格说明过程中提出的数据对象的逻辑表示。 编写概要设计文档:需要编写的文档有概要设计说明书、数据库设计说明书、集成测试计划等。 概要设计文档评审。(2)概要设计的图形工具常用的软件

4、结构设计工具是结构图(SC),也称程序结构图,它描述了软件系统的层次和分块结构关系。模块用一个矩形表示,矩形内注明模块的功能和名字;箭头表示模块间的调用关系。用带实心圆的箭头表示传递的是控制信息,用带空心圆的箭头表示传递的是数据。结构图的有关术语如下。Ø 深度:表示控制的层数。Ø 上级模块、下级模块:调用模块中上级模块,被调用模块是下级模块。Ø 宽度:整体控制跨度(最大模块数的层)的表示。Ø 扇入:调用一个给定模块的模块个数。Ø 扇出:一个模块直接调用的其他模块数。Ø 原子模块:树中位于叶子节点的模块。(3)面向数据流的设计方法典型的

5、数据流类型有两种:变换型和事务型。 变换型:是指信息沿输入通道进入系统,同时由外部形式变换成内部形成,进入系统的信息通过变换中心,经加工处理以后再沿输出通路变换成外部形式离开软件系统。 事务型:在很多软件应用中,存在某种作业数据流,它可以引发一个或多个处理,这些处理能够完成该作业要求的功能,这种数据流就叫做事务。(4)设计的准则 提高模块独立性。 模块规模适中。 深度、宽度、扇出和扇入适当。 使模块的作用域在该模块的控制域内。 应减少模块的接口和界面的复杂性。 设计成单入口、单出口的模块。 设计功能可预测的模块。3详细设计详细设计的任务是为软件结构图中的每个模块确定实现算法和局部数据结构,用某

6、种选定的表达工具表示算法和数据结构的细节。常用的过程图形设计工具如下。(1)程序流程图程序流程图是一种传统的、应用广泛的软件过程设计表示工具,通常称为程序框图。程序流程图表达直观、清晰,易于学习掌握,且独立于任何一种程序设计语言。构成程序流程图的最基本图符及含义如下所示。或:控制流:加工步骤:逻辑条件(2)N-S图为了避免程序图在描述程序逻辑时的随意性与灵活性,提出了用方框图来代替传统的程序流程图,通常把这种图称为N-S图。N-S图的基本图符及表示的5种控制结构如图7-20所示。任务1任务2任务3条件elsethen判定条件循环体循环体判定条件条件=1=2=nABCD 图7-20 N-S图图符

7、与构成的5种控制结构(3)PAD图PAD图是问题分析图(Problem Analysis Diagram)的英文缩写,它是继程序流程图和方框图之后,提出的又一种主要用于描述软件详细设计的图形表示工具。PAD图的基本图符及表示的控制结构如图7-21所示。条件AB选择型顺序型BAWHILEAWHILE重复型UNTIL重复型UNTILB 图7-21 PAD图图符与构成的5种控制结构除了以上3种工具外,还有判定表、判定树和结构化自然语言PDL等描述工具。 软件测试及调试1软件测试的目的与任务软件测试的目的是确保软件的质量,尽量找出软件错误并加以纠正,而不是证明软件没有错。因此,软件测试的任务可以规定两

8、点。(1)测试任务:通过采用一定的测试策略,找出软件中的错误。(2)调试任务:如果测试发现错误,则定位软件中的错误,并加以纠正。找错的活动称为测试,纠错的活动称为调试。2软件测试的准则(1)所有测试都应追溯到需求。(2)严格执行测试计划,排除测试的随意性。(3)充分注意测试中的群集现象。(4)程序员应避免检查自己的程序。(5)穷举测试不可能。(6)妥善保存测试计划、测试用例、出错统计和最终分析报告,为维护提供方便。3软件测试技术与方法软件测试的方法和技术是多种多样的,对于软件测试方法和技术,可以从不同的角度加以分类。若从是否需要执行被测软件的角度,可以分为静态测试和动态测试方法。若按照功能划分

9、可以分为白盒测试和黑盒测试。(1)静态测试与动态测试静态测试包括代码检查、静态结构分析、代码质量度量等,可以由人工完成,也可以借助软件工具。动态测试是基于计算机的测试,是为了发现错误而执行程序的过程。合理的测试用例是测试的关键,测试用例是为测试设计的数据。(2)白盒测试方法与测试用例白盒测试方法也称结构测试或逻辑驱动测试,它是根据软件产品的内部工作过程,检查内部成分,以确认每种内部操作符合设计规格要求。白盒测试把测试对象看成是一个打开的盒子。白盒测试是在程序内部进行,主要用于完成软件内部操作的验证。白盒测试的主要方法有逻辑覆盖、基本路径测试等。逻辑覆盖测试是指一系列以程序的内部逻辑结构为基础的

10、测试用例设计技术。 语句覆盖:执行足够的测试用例,使得程序中每个语句至少都能被执行一次。 路径覆盖:执行足够的测试用例,使程序中所有可能的路径都至少经历一次。 判定覆盖:使设计的测试用例保证程序中每个取值分支至少经历一次。 条件覆盖:设计的测试用例保证程序中每个判断的每个条件的可能取值至少执行一次。 判断-条件覆盖:设计足够的测试用例,保证程序中判断中每个条件的所有可能取值至少执行一次,同时每个判断的所有可能取值分支至少执行一次。基本路径测试是根据软件过程性描述中的控制流程确定程序的环路复杂性度量,用此度量定义基本路径集合,并由此导出一组测试用例对每一条独立执行路径进行测试。(3)黑盒测试方法

11、与测试用例黑盒测试方法也称为功能测试或数据驱动测试,它是对软件已经实现的功能是否满足需求进行测试和验证。黑盒测试完全不考虑程序内部的逻辑结构和内部特性,只依据程序的需求和功能规格说明,检查程序的功能是否符合它的功能说明。黑盒测试是在软件接口进行,完成功能验证。黑盒测试方法主要有等价类划分法、边界值分析法、错误推测法、因果图法等。其中,等价类划分法是将程序的所有可能的输入数据划分成若干部分,然后从每个等价类中选取数据作为测试用例。4软件测试实施软件测试过程一般按4个步骤进行,即单元测试、集成测试、验收测试(确认测试)和系统测试。(1)单元测试单元测试集中对软件设计的最小单位模块进行测试,主要是为

12、了发现模块内部可能存在的各种错误和不足。进行单元测试时,根据程序的内部结构设计测试用例,主要使用白盒测试法。由于各模块相对独立,因而对多个模块的测试可以同时进行,以提高测试效率。单元测试主要针对5个基本特性进行测试:模块接口、局部数据结构、重要的执行路径、出错处理和边界条件。(2)集成测试集成测试是测试和组装软件的过程。主要目的是发现与接口有关的错误,集成测试的依据是概要设计说明书,测试的内容主要是:软件单元的接口测试、全局数据结构测试、边界条件和非法输入的测试等。集成测试时将模块组装成程序通常采用两种方式:非增量方式组装和增量方式组装。(3)确认测试确认测试的任务是验证软件的功能和性能及其他特性是否满足了需求规格说明中确定的各种需求,以及软件配置是否完全、正确。确认测试的实施首先运用黑盒测试方法。(4)系统测试系统测试是把通过确认测试的软件作为基于计算机系统的一个元素,与整个系统的其他元素结合起来,在实际运行环境下,对计算机系统进行一系列的集成测试和确认测试。5软件调试实施在对程序进行了成功的测试之后将进入程序调试,程序调试的任务是诊断和改正程序中的错误。软件测试贯穿整个软件生命周期,调试主要在开发阶段。程序调试活动由两部分组成:其一是错误的定位,其二是

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论