《第十二章 面向对象实现精选文档.ppt》由会员分享,可在线阅读,更多相关《第十二章 面向对象实现精选文档.ppt(20页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、第十二章 面向对象实现本讲稿第一页,共二十页第十二章第十二章 面向对象实现面向对象实现12.1 程序设计语言12.2 程序设计风格12.3 测试策略12.4 设计测试用例本讲稿第二页,共二十页概述概述所谓面向对象实现,主要包括下述两项工作:把面向对象设计结果翻译成用某种程序设计语言书写的面向对象程序测试并调试面向对象程序面向对象程序的质量基本上由面向对象设计的质量决定,但是,所采用的编程语言的特点和程序设计风格也将对程序的可靠性、可重用性和可维护性产生深远影响。目前,测试仍然是保证软件可靠性的主要措施,对于面向对象的软件来说,情况也是如此:面向对象测试的目标,也是用尽可能低的测试成本发现尽可能
2、多的软件错误。但是,面向对象程序中特有的封装、继承和多态等机制,也给面向对象测试带来一些新特点。12.1 12.1 程序设计语言程序设计语言本讲稿第三页,共二十页12.1 12.1 程序设计语言程序设计语言12.1.1 面向对象语言的优点一致的表示方法 可重用性 可维护性12.1.2 面向对象语言的技术特点支持类与对象概念的机制 实现聚集结构的机制实现泛化结构的机制实现属性和服务的机制类型检查机制类库效率持久保持对象的机制 参数化类的机制 开发环境本讲稿第四页,共二十页12.2 12.2 程序设计风格程序设计风格12.1.3 选择面向对象语言的实际因素将来能否占主导地位 可重用性 类库和开发环
3、境售后服务 对运行环境的需求集成已有软件的难易程度1.提高可重用性为提高软件的可重用性,应该遵守下述准则:提高方法的内聚 减少方法的规模保持方法的一致性 把策略与实现分开全面覆盖输入条件的各种可能组合 尽量不使用全局信息 充分利用继承机制通过调用公用方法实现代码重用本讲稿第五页,共二十页12.1 12.1 程序设计风格程序设计风格2.提高可扩充性提高可重用性的准则同样也能提高程序的可扩充性。此外,下述的面向对象程序设计准则也有助于提高程序的可扩充性:封装类的实现细节 不要用一个方法遍历多条联链避免使用多分支语句 精心选择和定义公有方法通过因子分解实现代码重用本讲稿第六页,共二十页3.提高健壮性
4、 健壮性:在硬件故障、输入的数据无效或操作错误等意外环境下,系统能做出适当响应的程度。通常需要在健壮性和效率之间做出适当的折衷。为提高健壮性应该遵守下述准则:预防用户的错误操作 检查参数的合法性不要预先设定数据结构的限制条件先测试后优化本讲稿第七页,共二十页12.3 12.3 面向对象的测试策略面向对象的测试策略测试软件的基本策略是,从“小型测试”开始,逐步过渡到“大型测试”,即从单元测试开始,逐步进入集成测试,最后进行确认测试和系统测试。1.面向对象的单元测试对于面向对象的软件来说,单元测试的含义发生了很大变化现在,最小的可测试单元是封装起来的类和对象。一个类通常包含一组不同的操作,而一个特
5、定的操作也可能存在于一组不同的类中。因此,测试面向对象的软件时,不能再孤立地测试单个操作,而应该把操作作为类的一部分来测试。本讲稿第八页,共二十页12.3 12.3 面向对象的测试策略面向对象的测试策略2.面向对象的集成测试 因为在面向对象的软件中不存在层次的控制结构,传统的自顶向下和自底向上的集成策略就没有意义了。此外,由于构成类成分彼此间存在或直接的交互,因此一次集成一个操作到类中(传统的渐增式集成方法),通常是不可能的。面向对象软件的集成测试主要有下述两种策略:基于线程的测试基于使用的测试本讲稿第九页,共二十页12.3 12.3 面向对象的测试策略面向对象的测试策略3.面向对象的确认测试
6、在确认测试或系统测试层次,不再考虑类之间互相连接的细节。和传统的确认测试一样,面向对象软件的确认测试也集中检查用户可见的动作和用户可识别的输出。为了导出确认测试用例,测试人员应该认真研究动态模型和描述系统行为的脚本,以确定最可能发现用户交互需求错误的情景。本讲稿第十页,共二十页12.4 12.4 设计测试用例设计测试用例与传统软件测试(由软件的输入处理输出视图或实现模块的算法驱动测试用例的设计)不同,面向对象测试关注于设计适当的操作序列以检查类的状态。4.1 测试类的技术 设计测试用例以测试、单个类的技术,主要有随机测试、划分测试和基于故障的测试等3种。1.随机测试让类实例随机地执行一些类内定
7、义的操作,以测试类状态。如果应用系统的性质对操作的应用施加了一些限制,则可在最小操作序列的基础上随机增加一些操作,作为测试该类的测试用例。本讲稿第十一页,共二十页12.4 12.4 设计测试用例设计测试用例2.划分测试与测试传统软件时采用等价划分方法类似,测试类时采用划分测试方法也可以减少所需要的测试用例的数量。首先,把输入和输出分类,然后设计测试用例以测试划分出的每个类别。划分类别的方法主要有下述3种:基于状态划分这种方法根据类操作改变类状态的能力来划分类操作,然后设计测试用例,分别测试改变状态的操作和不改变状态的操作。基于属性划分这种方法根据类操作使用某个关键属性的情况来划分类操作。通常,
8、把类操作划分成使用属性、修改属性、不使用也不修改属性等3类,然后设计测试用例,分别测试每类操作。基于功能划分这种方法根据类操作完成的功能来划分类操作,然后为每个类别的操作设计测试序列。本讲稿第十二页,共二十页12.4 12.4 设计测试用例设计测试用例3.基于故障的测试这种方法与传统的错误推测法类似,也是首先推测软件中可能有的错误,然后设计出最可能发现这些错误的测试用例为了推测出软件中可能有的错误,应该仔细研究分析模型和设计模型,而且在很大程度上要依靠测试人员的经验和直觉。如果推测得比较准确,则使用基于故障的测试方法能够用相当低的工作量发现大量错误;反之,如果推测不准,这种方法的效果并不比随机
9、测试技术的效果好。4.2 集成测试技术开始集成面向对象的软件之后,测试用例的设计变得更加复杂。在这个测试阶段,必须对类间协作进行测试。和测试单个类相似,测试类协作可以使用随机测试方法和划分测试方法,以及基于情景的测试和行为测试来完成。本讲稿第十三页,共二十页12.4 12.4 设计测试用例设计测试用例1.多类测试对每个客户类,使用类操作符列表来生成一系列随机测试序列。这些操作符向服务类实例发送消息。对所生成的每个消息,确定协作类和在服务器对象中的对应操作符。对服务器对象中的每个操作符(已经被来自客户对象的消息调用),确定传递的消息。对每个消息,确定下一层被调用的操作符,并把这些操作符结合进测试
10、序列中。本讲稿第十四页,共二十页银行系统的类-协作图12.4 12.4 设计测试用例设计测试用例本讲稿第十五页,共二十页12.4 12.4 设计测试用例设计测试用例2.从动态模型导出测试用例类的状态图有助于导出测试该类(及与其协作的那些类)的动态行为的测试用例。设计出的测试用例应该覆盖该类的所有状态,也就是说,操作序列应该使得该类实例遍历所有允许的状态转换。在类的行为导致与一个或多个类协作的情况下,应该使用多张状态图以跟踪系统的行为流。本讲稿第十六页,共二十页12.4 12.4 设计测试用例设计测试用例account类的状态转换图本讲稿第十七页,共二十页D本讲稿第十八页,共二十页D本讲稿第十九页,共二十页B本讲稿第二十页,共二十页