[IT认证]软件工程讲义9.ppt
《[IT认证]软件工程讲义9.ppt》由会员分享,可在线阅读,更多相关《[IT认证]软件工程讲义9.ppt(101页珍藏版)》请在三一办公上搜索。
1、软件工程,1,软件工程 第九章 软件质量,9.1 软件质量和质量模型9.2 软件质量保证9.3软件配置管理,软件工程,2,9.1 软件质量与质量模型,9.1.1 软件质量的概念,ANSI/IEEE Std 729-1983定义软件质量为“与软件产品满足规定的和隐含的需求的能力有关的特征或特性的全体”。ISO 8402-1994定义软件质量为“反映实体满足明确和隐含需要的能力的特性的总和”。此处,实体是“可以单独描述和研究的事物”,如产品,活动,过程,组织和体系等。,软件工程,3,由此可知,质量是产品、体系或过程的一组固有特性,反映的是满足顾客和其他相关方面要求的程度。David Garvin提
2、出,“质量是一个复杂的多层面的概念”:从先验论角度看,质量是可以识别出来的,但不能明确定义的。从用户角度看,质量是对目标的满足程度。从制造角度看,质量是对规范的符合程度。从产品角度看,质量是产品的内在特征。,软件工程,4,从基于价值的角度看,质量依赖于顾客愿意出多少钱购买。按用户角度定义质量,J.M.Juran 提出“满足使用要求的基础是质量特征”。下面是一些有关质量的术语:软件质量管理是对软件在质量方面指挥和控制组织的协调活动。通常包括制定质量方针和质量目标以及质量策划、质量控制、质量保证和质量改进。质量方针是由组织的最高管理者正式发布的该组织总的质量宗旨和方向。,软件工程,5,质量目标是在
3、质量方面所追求的目的。质量策划是质量管理的一部分,致力于制定质量目标并规定必要的运行过程和相关资源以实现质量目标。质量控制是质量管理的一部分,致力于满足质量要求。质量保证是质量管理的一部分,致力于保障质量会得到满足的信任度。质量改进是质量管理的一部分,致力于增强满足质量要求的能力。,软件工程,6,9.1.2 软件质量模型,为满足软件的各项精确定义的功能、性能需求,符合文档化的开发标准,需要相应地给出或设计一些质量特性及其组合。如果这些质量特性及其组合都能在产品中得到满足,则这个软件产品质量就是高的。软件质量是各种特性的复杂组合。它随着应用的不同而不同,随着用户提出的质量要求不同而不同。软件质量
4、特性,反映软件的本质。讨论一个软件的质量,归结到定义软件的质量特性。,软件工程,7,定义一个软件的质量,就等价于为该软件定义一系列质量特性。人们通常把影响软件质量的特性用软件质量模型来描述。软件质量特性定义成分层模型。最基本的叫做基本质量特性,它可以由一些子质量特性定义和度量。这些子特性在必要时又可由它的一些子特性定义和度量。1976年 Boehm质量模型1979年 McCall质量模型1985年 ISO质量模型,软件工程,8,Boehm质量模型,软件工程,9,McCall质量模型,可维护性(Maintainability)可测试性(Testability)灵活性(Flexibility),正
5、确性(Correctness)可靠性(Reliability)可使用性(Usability)效率(Efficiency)完整性(Integrity),互连性(Interoperability)可移植性(Portability)复用性(Reusability),软件工程,10,ISO的软件质量评价模型,按照1991年 ISO发布的 ISO/IEC 9126 质量特性国际标准,软件质量度量模型由三层组成 软件质量特性 软件质量子特性 软件质量度量评价准则高层和中层建立国际标准,低层可由各使用单位视实际情况制定。,软件工程,11,软件质量,功能性,可靠性,可维护性,效率,可使用性,可移植性,适合性,
6、准确性,互操作性,依从性,安全性,成熟性,容错性,易恢复性,易理解性,易学习性,易操作性,时间特性,资源特性,易分析性,稳定性,易变更性,易测试性,易安装性,易替换性,适应性,遵循性,质量特性,质量子特性,质量度量准则,使用单位自行规定,ISO 9126质量模型,软件工程,12,其中,表示有利影响,表示不利影响。,质量特性之间的竞争,软件工程,13,1994年对ISO/IEC 9126开始进行修正,将原标准修订为两个序列标准:ISO/IEC 9126信息技术 软件产品质量,描述新的软件质量模型,分为 4 个部分:质量模型(9126-1)内部质量(9126-2)外部质量(9126-3)使用质量(
7、9126-4)ISO/IEC 14598信息技术 软件产品评价,详细描述软件质量评价的方法,分为 6 个部分:,软件工程,14,概述(14598-1)策划和管理(14598-2)开发方过程(14598-3)获取方过程(14598-4)评价方过程(14598-5)评价模块的文档(14598-6)修订版保留了 6 个质量特性,但明确了它们与内部度量和外部度量的关系,并解释了这些特性与使用质量之间的关系。修订版还给出了一个质量模型的规格说明,引入了使用质量。,软件工程,15,ISO/IEC 9126与ISO/IEC 14598之间的关系,软件工程,16,内部质量和外部质量的质量模型,外部质量是软件产
8、品在规定条件下使用时,满足规定的和隐含的要求的程度。外部质量是从外部观点看软件产品的全部特性。内部质量是软件产品在规定条件下使用时,决定其满足规定的和隐含的要求的能力的产品属性的全体。内部质量是从内部的观点看软件产品的全部特性。在质量模型中有 6 个软件质量特性,这些特性按用户观点描述软件的外部质量,每个质量特性按开发者的观点又分解为子特性。,软件工程,17,外部和内部质量的质量模型,软件工程,18,使用质量的质量模型,使用质量是软件产品在规定的使用环境中,规定的用户能实现规定目标的要求,并具有有效性、生产率、安全性和满意度的能力。使用质量是从软件所处的环境的观点,用软件在这个环境中的使用绩效
9、来测量的,而不是依靠软件本身的特性来测量。,软件工程,19,在生存周期中各种质量特性的使用,软件的生存周期可以划分为三个大的阶段。在软件需求定义阶段要定义软件的质量要求;在软件产品开发阶段要使得软件产品具有要求的质量;在软件运行和维护阶段要测量软件是否达到了用户的质量要求并维护软件的性能水平。用户质量要求可以用使用质量度量、外部质量度量表达,有时也可以用内部质量度量来表达。用这些度量表达的要求将作为产品确认的准则。,软件工程,20,软件工程,21,外部质量要求从外部的观点规定要求的质量级别,包括从用户质量要求导出的要求。外部质量要求用作各开发阶段的确认目标,在质量要求规格说明中用外部质量度量规
10、定,并应当转换为内部质量要求。内部质量要求从内部的观点规定要求的质量级别,用于说明中间产品的特性。内部质量要求可以用作各开发阶段的确认目标,也可以用于定义开发策略和开发期间评价和验证的准则。内部质量要求用内部度量数据定量地规定。,软件工程,22,软件产品质量评价,软件产品质量在开发过程中形成,在使用中表现。,软件工程,23,软件产品质量可通过测量内部质量特性(中间产品的静态测量数据)外部质量特性(代码执行的行为)使用质量特性(使用此软件的系统行为)来评价。目的是使产品在具体使用环境中具有要求的效能。为了满足开发者、维护者、获取者和最终用户的要求,软件产品的质量要求通常包括内部质量、外部质量和使
11、用质量的评价准则。,软件工程,24,可依赖性 dependability,对于某些高可靠性系统,质量特性“可依赖性”显得非常重要,它有四个主要方面:可用性(Availability):系统在任何时间都能得到并能够执行有用服务的可能性。可靠性(Raliability):系统在给定的时段内能提供希望的服务的可能性。安全性或防护性(Safety):系统防止发生给人和环境造成伤害的失效的可能性。安全性或保密性(Security):系统能够抵抗意外或蓄意的入侵的可能性。,软件工程,25,可依赖性的层次,软件工程,26,9.1.3 提高质量的方法-原型化方法,软件需求是度量软件质量的基础。不符合需求的软件
12、就不具备质量。它是各种特性的复杂组合。它随着应用的不同而不同,随着用户提出的质量要求不同而不同。因此与用户的交流成为提高软件质量的关键。在系统开发中,与用户进行交流的基本技术是原型化方法。系统原型是软件系统的初始版本,用于展示设计选择、发现问题和给出可能的解决方案。,软件工程,27,软件原型支持需求工程的两项活动:需求获取需求有效性验证其他用途:用户培训系统测试主要分类:进化式原型开发抛弃式原型开发,软件工程,28,1.进化式原型开发,基本思路是:先给出一个系统的最初实现,让用户去使用和评价,不断进行细化和改善,经过多次这样的反复过程后形成最终的完善的系统。,软件工程,29,2.抛弃式原型开发
13、,基本思路是:原型的根本作用是弄清楚需求和为风险评估提供补充信息。通过评估后,原型被抛弃,重新规划和实施系统的开发。,软件工程,30,9.1.4 软件质量的度量和评价,软件质量特性度量有两类:预测型和验收型。预测度量是利用定量或定性的方法,估算软件质量的评价值,以得到软件质量的比较精确的估算值。验收度量是在软件开发各阶段的检查点,对软件的要求质量进行确认性检查的具体评价值,它对开发过程中的预测进行评价。,软件工程,31,预测度量有两种。第一种叫做尺度度量,这是一种定量度量。它适用于一些能够直接度量的特性,例如,出错率定义为:错误数KLOC单位时间。第二种叫做二元度量,这是一种定性度量。它适用于
14、一些只能间接度量的特性,例如,可使用性、灵活性等等。,软件工程,32,尺度度量检查表,软件工程,33,二元度量检查表,软件工程,34,通过对照检查项目,确定一种质量特性的有无。例如,在设计和编码阶段的复杂性度量,利用尺度度量方法来做。对模块复杂性的度量采用McCabe 环路度量。对于二元度量,可针对检查表中每一项都应给以记分,指定信息存在时记“1”,否则记“0”。表中所有各项的分数相加,即得度量结果。,软件工程,35,9.2 软件质量保证9.2.1 质量保证的概念,什么是质量保证?ISO/IEC 12207:1995 指出:质量保证是一个有计划、有组织的活动,它向所有相关的人提供证据,以证明质
15、量功能正在按质量要求运行的信心。质量保证的目的是内部质量保证:在组织内部向管理者提供信任保证;外部质量保证:向顾客或第三方认证提供信任保证;,软件工程,36,9.2.2 软件质量保证过程与活动,ISO/IEC 12207:1995指出:软件质量保证过程(SQA)是恰当保证为项目生存周期中的软件产品和过程符合规定需求和已制定计划提供足够保证的过程。软件质量保证过程包括4方面的活动:过程实施产品质量保证过程质量保证质量保证体系的质量保证,软件工程,37,1.美国SEI推荐的软件质量保证活动,为项目制定SQA计划 该计划规定了软件开发小组和质量保证小组需要执行的质量保证活动。SQA计划的要点包括:需
16、要进行哪些评价?需要进行哪些审计和评审?项目采用的标准;错误报告的要求和跟踪过程;SQA小组应产生哪些文档?向软件项目组提供的反馈数量等。,软件工程,38,参与开发该软件项目的软件过程描述 软件开发小组为开发活动选择软件过程,SQA 小组评审过程说明,确保该过程与组织政策、内部、外界标准及软件项目计划的其他部分相符。评审各项软件工程活动 评审各项软件工程活动,核实其是否符合已定义的软件过程。为此,SQA小组必须识别、记录和跟踪所有偏离过程的偏差,核实其是否已经改正。,软件工程,39,审核指定的软件工作产品 审核指定的软件工作产品,核实其是否符合已定义的软件过程中的相应部分。记录软件工作及软件工
17、作产品的偏差 确保软件工作及工作产品中的偏差已被记录在案,并根据预定规程进行处理。跟踪问题的解决 记录所有不符合部分,向管理部门报告。跟踪不符合的部分直到问题得到解决。协调变更的控制与管理。帮助收集和分析软件度量的信息。,软件工程,40,2.微软提出的软件质量保证检查表,你识别出对你的项目很重要的质量特性了吗?你让其他人都知道项目的目标了吗?你对外部质量特性(正确性、可用性、有效性、可靠性、完整性、适用性、精确性和健壮性)和内部质量特性(可维护性、灵活性、可移植性、可复用性、可读性、可测试性和可理解性)作了区分吗?有没有想过有些特性是冲突的,而有些是互补的?,软件工程,41,你的项目有没有采用
18、几种不同的缺陷发现技术来分析不同类型的错误?你的项目计划中有没有包括在软件开发不同阶段进行质量保证的步骤?质量有没有测量,以便于了解什么地方质量提高了,什么地方质量下降了?管理层是否了解质量保证在(开发)前期增加成本而在后期节省成本?,软件工程,42,3.日本软件质量管理协会提出的质量保证活动,用户要求定义熟练掌握正确定义用户要求的技术。熟练使用和指导他人使用定义软件需求的支持工具。重视领导全体开发人员收集和积累有关用户业务领域的各种业务的资料和技术技能。力争不重复劳动考虑哪些既有软件可以复用。,软件工程,43,在开发过程中,随时考虑所生产软件的复用性。掌握开发新软件的方法 在开发新软件的过程
19、中大力使用和推行 软件工程中所介绍的开发方法和工具。使用先进的开发技术:如结构化技术、面向对象技术。使用数据库技术或网络化技术。应用开发工具或环境。改进开发过程。,软件工程,44,组织外部力量协作的方法一个软件自始至终由同一个软件组织开发是最理想的。但在现实中常常难以做到。改善对外部协作部门的开发管理。必须明确规定进度管理、质量管理、交接检查、维护体制等各方面要求,建立跟踪检查体制。排除无效劳动一种无效劳动是因需求规格说明有误、设计有误而造成的返工。定量记录返工工作量,收集和分析返工劳动花费数据,采取措施减少返工。,软件工程,45,另一种无效劳动是重复劳动,即相似的软件在几个地方同时开发。建立
20、互相交流、信息往来通畅、具横向交流特征的信息流通网。发挥每个开发者的能力软件生产是人的智能生产活动,它依赖于人的能力和开发组织团队的能力。开发者必须有学习各专业业务知识、生产技术和管理技术的能动性。管理者或产品服务者要制定技术培训计划、技术水平标准,及适用于将来需要的中长期技术培训计划。,软件工程,46,7)提高软件开发的工程能力要想生产出高质量的软件产品必须有高水平的软件工程能力。在软件开发环境或软件工具箱的支持下,运用先进的开发技术、工具和管理方法开发软件的能力。提高计划和管理质量能力项目开发初期计划阶段的项目计划评价。计划执行过程中对计划完成报告的评价。将评价、评审工作在工程实施之前就列
21、入整个开发工程的工程计划中。提高软件开发项目管理的精确度。,软件工程,47,9.2.3 软件质量保证体系,软件的质量保证活动,是涉及各个部门的部门间的活动。为顺利开展质量保证活动,必须事先明确部门间的质量保证业务,确立部门间的联合与协作的机构,这个机构就是质量保证体系。必须明确反馈途径。必须明确各部门的职责。必须确定保证系统运行的方法、工具、有关文档资料,以及系统管理的规程和标准。,软件工程,48,必须明确决定是否可向下一阶段进展的评价项目和评价准则。必须不断地总结系统管理的经验教训,能够修改系统。软件质量保证规程和技术准则规定在项目的哪个阶段进行评审及如何评审;规定在项目的哪个阶段应当产生哪
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- IT认证 IT 认证 软件工程 讲义
链接地址:https://www.31ppt.com/p-4594077.html