1、软件项目管理l软件质量管理的基本概念软件质量管理的基本概念l软件质量控制软件质量控制l缺陷预防缺陷预防l质量体系质量体系l软件项目质量管理计划(案例)软件项目质量管理计划(案例)l缺陷跟踪工具缺陷跟踪工具l软件质量是指软件满足明确说明或者隐含的需软件质量是指软件满足明确说明或者隐含的需求的程度。求的程度。l用户需求是衡量软件质量的基础。用户需求是衡量软件质量的基础。l除满足明确定义的需求外,还要满足隐含的需除满足明确定义的需求外,还要满足隐含的需求。求。l软件项目的三大目标:软件项目的三大目标:质量进度费用l软件质量问题可能导致经济损失甚至灾难性的软件质量问题可能导致经济损失甚至灾难性的后果。
2、后果。l质量是软件产品和软件组织的生命线。质量是软件产品和软件组织的生命线。l质量问题会增加开发和维护软件产品的成本。质量问题会增加开发和维护软件产品的成本。可靠性可靠性可用性可用性安全性安全性可维护性可维护性机密性机密性软件质量软件质量功能功能性能性能易用性易用性可信性可信性l软件的质量形成于产品或者服务的开发过程中,软件的质量形成于产品或者服务的开发过程中,而不是事后的检查(如测试)。而不是事后的检查(如测试)。l世纪年代起,质量管理逐步从单一的关注产品,世纪年代起,质量管理逐步从单一的关注产品,转移到关注生产好产品的过程上,并且将过程转移到关注生产好产品的过程上,并且将过程的作用扩大到了
3、组织运行的所有领域。的作用扩大到了组织运行的所有领域。l当过程不断被重复,其性能会趋于稳定当过程不断被重复,其性能会趋于稳定l结果可预测结果可预测l对现行执行可监测对现行执行可监测质量得到保证质量得到保证实施的过程性能实施的过程性能稳定过程的上下控制界稳定过程的上下控制界l特殊原因造成过程性能不稳定。特殊原因造成过程性能不稳定。l 根除特殊原因,使过程性能稳定,防止质量根除特殊原因,使过程性能稳定,防止质量问题的出现。问题的出现。造成不稳定的特殊原因造成不稳定的特殊原因l质量成本是为了达到产品或服务的质量而付出质量成本是为了达到产品或服务的质量而付出的所有努力的总成本,包括三部分:的所有努力的
4、总成本,包括三部分:l预防成本:为防止将缺陷引入软件而进行的预预防成本:为防止将缺陷引入软件而进行的预防工作所消耗的费用。防工作所消耗的费用。l评价成本:检查软件是否包含缺陷的工作所消评价成本:检查软件是否包含缺陷的工作所消耗的费用。耗的费用。l失效成本:修复缺陷工作所消耗的成本。失效成本:修复缺陷工作所消耗的成本。l ( )成本模型)成本模型预防预防评估评估失效失效培训审查废品计划测试返工过程研究和改进审计修复供应商调查监控 咨询度量缺陷分析获得资格验证服务分析退货确认投诉处理和解决 $ $ $ $ $ $ 在项目早期预防和检测缺陷比在项目晚期在项目早期预防和检测缺陷比在项目晚期检测和排除缺
5、陷更有效、更节省成本。检测和排除缺陷更有效、更节省成本。l软件质量管理的基本概念软件质量管理的基本概念l软件质量控制软件质量控制l缺陷预防缺陷预防l质量体系质量体系l软件项目质量管理计划(案例)软件项目质量管理计划(案例)l缺陷跟踪工具缺陷跟踪工具l质量控制质量控制( , )是确定项目结果与质量标准是否相是确定项目结果与质量标准是否相符,并及时纠正产品缺陷的过程。符,并及时纠正产品缺陷的过程。l质量控制的主要手段是验证与确认质量控制的主要手段是验证与确认( )l验证()验证():是否正确地构造了产品?以开发者的视是否正确地构造了产品?以开发者的视角进行。角进行。l确认()确认():是否构造了正
6、确的产品?以用户的视角是否构造了正确的产品?以用户的视角进行。进行。需求分析需求分析需求评审需求评审设计设计设计评审设计评审编码编码代码审查代码审查系统测试系统测试界面原型界面原型需求确认需求确认需求确认需求确认确认测试确认测试测试开发测试开发质量控质量控制方法制方法静态方法:评审静态方法:评审技术评审技术评审代码评审代码评审动态方法:测试动态方法:测试单元测试单元测试集成测试集成测试确认测试确认测试l技术评审是指在完成一项工作后,把工作产品技术评审是指在完成一项工作后,把工作产品分发给合作者,让合作者检查其中的缺陷。然分发给合作者,让合作者检查其中的缺陷。然后开会讨论工作产品并产生需要返工的
7、缺陷列后开会讨论工作产品并产生需要返工的缺陷列表。表。l技术评审的主要对象:需求和设计规格说明、技术评审的主要对象:需求和设计规格说明、测试计划、用户手册等。测试计划、用户手册等。l组织召开评审会议:一般应有个相关人员参加,组织召开评审会议:一般应有个相关人员参加,会前每个参加者做好准备,评审会议一般不超会前每个参加者做好准备,评审会议一般不超过两个小时。过两个小时。l在评审会议上,由开发小组对提交的评审对象在评审会议上,由开发小组对提交的评审对象进行讲解。进行讲解。l评审组可对开发小组提问,提出建议和要求,评审组可对开发小组提问,提出建议和要求,展开讨论。展开讨论。l会议结束时必须做出以下三
8、个决策之一:会议结束时必须做出以下三个决策之一:l接受该产品,不需要做修改。接受该产品,不需要做修改。l由于错误严重,拒绝接受。由于错误严重,拒绝接受。l暂时接受该产品,但需要对某一部分进行修改。暂时接受该产品,但需要对某一部分进行修改。l评审报告与记录:对所提出的问题要进行记录,并评审报告与记录:对所提出的问题要进行记录,并产生一个评审报告。产生一个评审报告。l同行评审是一种特殊类型的技术评审。同行评审是一种特殊类型的技术评审。l由与工作产品开发人员具有同等背景和能力的由与工作产品开发人员具有同等背景和能力的人员对工作产品进行技术评审,因此非常有利人员对工作产品进行技术评审,因此非常有利于发
9、现工作产品中的问题。于发现工作产品中的问题。l编码阶段的一种技术评审,由一组人员对程序编码阶段的一种技术评审,由一组人员对程序进行阅读和静态分析,可以很有效地检查程序进行阅读和静态分析,可以很有效地检查程序代码中的缺陷。代码中的缺陷。l评审内容:程序是否符合编码规范,程序结构评审内容:程序是否符合编码规范,程序结构是否合理,算法和程序逻辑是否正确,程序性是否合理,算法和程序逻辑是否正确,程序性能怎样等。能怎样等。l很多程序逻辑错误很难通过测试发现。很多程序逻辑错误很难通过测试发现。l缺陷跟踪是指从缺陷被发现开始到被改正为止缺陷跟踪是指从缺陷被发现开始到被改正为止的整个跟踪流程。的整个跟踪流程。
10、l缺陷跟踪一般需要软件工具支持。常用的工具缺陷跟踪一般需要软件工具支持。常用的工具有、有、 等。等。l初期故障率:指软件在初期故障期(一般以软初期故障率:指软件在初期故障期(一般以软件交付给用户后的三个月内为初期故障期)内件交付给用户后的三个月内为初期故障期)内单位时间的故障数。单位时间的故障数。l 用来评价交付使用的软件的质量,预测什么用来评价交付使用的软件的质量,预测什么时候软件运行达到基本稳定。时候软件运行达到基本稳定。l 一般以每小时的故障数为单位。一般以每小时的故障数为单位。l偶然故障率:指软件在偶然故障期(一般以软偶然故障率:指软件在偶然故障期(一般以软件交付给用户后的个月以后为偶
11、然故障期)内件交付给用户后的个月以后为偶然故障期)内单位时间的故障数。单位时间的故障数。l 它用来度量软件处于稳定状态下的质量。它用来度量软件处于稳定状态下的质量。l 一般以每小时的故障数为单位。一般以每小时的故障数为单位。l平均失效前时间(平均失效前时间( ,):指软件在失效前正,):指软件在失效前正常工作的平均统计时间。常工作的平均统计时间。l 用来度量软件的可靠性。用来度量软件的可靠性。l平均修复时间(平均修复时间( ,):指软件失效后,使其,):指软件失效后,使其恢复正常工作所需要的平均统计时间。恢复正常工作所需要的平均统计时间。l 用来度量软件的可维护性。用来度量软件的可维护性。l缺
12、陷密度:指软件单位数量的源代码中隐藏的缺陷密度:指软件单位数量的源代码中隐藏的缺陷数量。缺陷数量。l 通常以每千行无注解源代码为一个单位。通常以每千行无注解源代码为一个单位。l软件质量管理的基本概念软件质量管理的基本概念l软件质量控制软件质量控制l缺陷预防缺陷预防l质量体系质量体系l软件项目质量管理计划(案例)软件项目质量管理计划(案例)l缺陷跟踪工具缺陷跟踪工具l优点:主动优点:主动l 改进软件过程,降低出错几率改进软件过程,降低出错几率l 降低质量成本,实现项目效益降低质量成本,实现项目效益找到根本原因找到根本原因消除根本原因消除根本原因l:选择缺陷数据。:选择缺陷数据。l 对小项目,可选
13、择某一时期内发现的所有缺陷。对小项目,可选择某一时期内发现的所有缺陷。l 对大项目,可选择一个缺陷样本集合。对大项目,可选择一个缺陷样本集合。l:分析缺陷的根本原因:分析缺陷的根本原因l 对缺陷逐个进行分析,常以会议的方式进行。对缺陷逐个进行分析,常以会议的方式进行。l 可对分析出的根本原因进行分类,例如:可对分析出的根本原因进行分类,例如:l :疏忽、培训、通信失效、书写错误:疏忽、培训、通信失效、书写错误l :开发阶段相关、人员相关、项目相关、复审:开发阶段相关、人员相关、项目相关、复审相关相关缺陷原因分析工具缺陷原因分析工具因果图(鱼骨图)因果图(鱼骨图)l:识别公共原因,制定改进措施。
14、识别公共原因,制定改进措施。l 在逐个分析了缺陷之后,还要对分析得到的在逐个分析了缺陷之后,还要对分析得到的根本原因进行综合和归纳,识别导致缺陷产生根本原因进行综合和归纳,识别导致缺陷产生的公共原因,并制定有关过程、技术和人员管的公共原因,并制定有关过程、技术和人员管理方面的改进措施。理方面的改进措施。l软件质量管理的基本概念软件质量管理的基本概念l软件质量控制软件质量控制l缺陷预防缺陷预防l质量体系质量体系l软件项目质量管理计划(案例)软件项目质量管理计划(案例)l缺陷跟踪工具缺陷跟踪工具l根据标准,质量体系的定义是:为实施质量管根据标准,质量体系的定义是:为实施质量管理所需的组织结构、责任
15、、工序、工作过程和理所需的组织结构、责任、工序、工作过程和资源。资源。组织结构工 序过 程资 源质量体系l一个企业的质量体系是企业质量管理的规范,一个企业的质量体系是企业质量管理的规范,是企业长期遵循和需要重复实施的标准。是企业长期遵循和需要重复实施的标准。l质量体系可参照一定的标准实施,例如、系列质量体系可参照一定的标准实施,例如、系列等。等。l质量体系内容的核心是建立、执行和维护(改质量体系内容的核心是建立、执行和维护(改进)软件生产过程,以保证最终生产出的软件进)软件生产过程,以保证最终生产出的软件产品达到用户综合的质量要求。产品达到用户综合的质量要求。过程改进组织程序规范产品标准保证执
16、行决策、建立、维护包含关键过程域支持过程域过程规范产品过程执行组织质量保证组织保证质量体系要素关系图质量体系要素关系图 质量文件体系支持过程域产出l全面质量管理是指通过全体员工的参与,改进全面质量管理是指通过全体员工的参与,改进流程、产品、服务和公司文化,使企业运作的流程、产品、服务和公司文化,使企业运作的每一过程都做到满足客户需要,从而达到客户每一过程都做到满足客户需要,从而达到客户满意。满意。核心思想核心思想全员性全员性(全员参与质量管理)(全员参与质量管理)全过程性全过程性(管理好质量形成的全过程)(管理好质量形成的全过程)全面性全面性(和顾客交互的所有环节)(和顾客交互的所有环节)l强
17、调建立以过程为核心的组织文化强调建立以过程为核心的组织文化l以为客户创造价值为目标,识别组织内部的所以为客户创造价值为目标,识别组织内部的所有过程有过程l所有人员的职责和协作基于过程所有人员的职责和协作基于过程l强调过程的不断优化强调过程的不断优化l更强调预防而不是质量控制更强调预防而不是质量控制l要求对过程不断进行优化要求对过程不断进行优化l软件质量管理的基本概念软件质量管理的基本概念l软件质量控制软件质量控制l缺陷预防缺陷预防l质量体系质量体系l软件项目质量管理计划(案例)软件项目质量管理计划(案例)l缺陷跟踪工具缺陷跟踪工具l软件项目质量管理计划一般应满足以下要求:软件项目质量管理计划一
18、般应满足以下要求:l确定项目应达到的质量目标和所有特性的要求;确定项目应达到的质量目标和所有特性的要求;l确定项目中的质量活动和质量控制程序;确定项目中的质量活动和质量控制程序;l确定项目采用的控制手段及合适的验证手段和方确定项目采用的控制手段及合适的验证手段和方法;法;l确定和准备质量记录。确定和准备质量记录。l制订软件项目质量管理计划的依据是企业的质量制订软件项目质量管理计划的依据是企业的质量体系和项目的特点。体系和项目的特点。l软件质量活动必须经过规划软件质量活动必须经过规划l软件质量活动规划必须明文规定软件质量活动规划必须明文规定l质量活动必须尽早开始质量活动必须尽早开始l质量小组必须
19、独立存在质量小组必须独立存在l质量小组的人员应该经过必要的培训质量小组的人员应该经过必要的培训l软件质量管理的基本概念软件质量管理的基本概念l软件质量控制软件质量控制l缺陷预防缺陷预防l质量体系质量体系l软件项目质量管理计划(案例)软件项目质量管理计划(案例)l缺陷跟踪工具缺陷跟踪工具l是公司提供的一个开源的缺陷跟踪工具,在全是公司提供的一个开源的缺陷跟踪工具,在全世界拥有大量用户。世界拥有大量用户。l它能够为软件组织建立一个完善的缺陷跟踪体它能够为软件组织建立一个完善的缺陷跟踪体系,包括报告缺陷、查询缺陷记录并产生报表、系,包括报告缺陷、查询缺陷记录并产生报表、处理解决缺陷、管理员系统初始化
20、和设置等。处理解决缺陷、管理员系统初始化和设置等。l基于方式运行,安装简单,易于掌握。基于方式运行,安装简单,易于掌握。l缺陷从最初的报告到最后的关闭,都有详细的缺陷从最初的报告到最后的关闭,都有详细的操作记录,确保了缺陷不会被忽略,并允许用操作记录,确保了缺陷不会被忽略,并允许用户在检查缺陷状态时获取历史记录。户在检查缺陷状态时获取历史记录。l提供强大的查询匹配能力,能根据各种条件组提供强大的查询匹配能力,能根据各种条件组合进行缺陷查询,并能够记忆搜索条件。合进行缺陷查询,并能够记忆搜索条件。l当缺陷状态发生改变时,会自动发送邮件通知当缺陷状态发生改变时,会自动发送邮件通知相关责任人。相关责
21、任人。l自带基于数据库的报表生成功能,主要生成两自带基于数据库的报表生成功能,主要生成两类图表:基于表格的视图和图形视图(条形图、类图表:基于表格的视图和图形视图(条形图、线图、饼状图)。线图、饼状图)。l报告缺陷报告缺陷l分配缺陷分配缺陷l处理缺陷处理缺陷l验证已解决的缺陷验证已解决的缺陷l质量管理的基本概念质量管理的基本概念l 软件质量、质量属性、质量形成、质量成本软件质量、质量属性、质量形成、质量成本l质量控制质量控制l 技术评审、同行评审、代码评审技术评审、同行评审、代码评审l 缺陷跟踪缺陷跟踪l 常用质量度量常用质量度量l缺陷预防缺陷预防l质量体系质量体系l 质量体系的构成、特征,质量体系的构成、特征,l质量管理计划(案例)质量管理计划(案例)l缺陷跟踪工具缺陷跟踪工具l质量控制活动主要包括哪些?质量控制活动主要包括哪些?l简述质量体系和项目质量管理计划的区别。简述质量体系和项目质量管理计划的区别。