软件需求工程09-634378.pptx
《软件需求工程09-634378.pptx》由会员分享,可在线阅读,更多相关《软件需求工程09-634378.pptx(28页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第六章第六章 软件需求验证软件需求验证周立新周立新 博士博士北京大学软件与微电子学院北京大学软件与微电子学院课程提纲课程提纲1.1.软件需求基本理论和概念软件需求基本理论和概念 2.2.软件需求工程过程软件需求工程过程 3.3.软件需求获取软件需求获取 4.4.软件需求分析软件需求分析 5.5.软件需求规格说明软件需求规格说明 6.6.软件需求验证软件需求验证 7.7.软件需求管理软件需求管理 8.8.软件需求实现软件需求实现 9.9.软件需求工程新进展软件需求工程新进展 10.10.软件需求开发与需求管理工具软件需求开发与需求管理工具内容提要软件的质量属性分析需求质量验证需求评审需求测试 1
2、.软件的质量属性分析软件的质量属性分析软件质量属性软件质量属性(或质量因素或质量因素)的特性是系统非功能(也叫非的特性是系统非功能(也叫非行为)部分的需求。这些特性包括:行为)部分的需求。这些特性包括:产品的易用程度如何,产品的易用程度如何,执行速度如何,执行速度如何,可靠性如何,可靠性如何,当发生异常情况时,系统如何处理等。当发生异常情况时,系统如何处理等。质量属性区分:质量属性区分:一种属性分类的方法是把在运行时可识别的特性与那一种属性分类的方法是把在运行时可识别的特性与那些不可识别的特性区分开;些不可识别的特性区分开;另一种方法是把对用户很重要的可见特性与对开发者另一种方法是把对用户很重
3、要的可见特性与对开发者和维护者很重要的不可见特性区分开。和维护者很重要的不可见特性区分开。那些对开发者具有重要意义的属性使产品易于更改、那些对开发者具有重要意义的属性使产品易于更改、验证,并易于移植到新的平台上,从而可以间接地满足客验证,并易于移植到新的平台上,从而可以间接地满足客户的需要。户的需要。软件质量属性列表软件质量属性列表 对用户最重要的属性:对开发者最重要的属性:可用性(availability)可维护性(maintainability)高效性(efficiency)可移植性(portability)灵活性(flexibility)可重用性(reusability)完整性(inte
4、grity)可测试性(testability)互操作性(interoperability)可靠性(reliability)健壮性(robustness)Relationships among selected quality attributes 2.需求质量验证需求验证需求验证是需求开发的第四部分(其余三是需求开发的第四部分(其余三个为获取、分析和编写规格说明),个为获取、分析和编写规格说明),所包所包括的活动是为了确定以下几方面的内容:括的活动是为了确定以下几方面的内容:软件需求规格说明正确描述了预期的系统行为软件需求规格说明正确描述了预期的系统行为和特征和特征。从系统需求或其它来源中得到
5、软件需求。从系统需求或其它来源中得到软件需求。需求是完整的和高质量的。需求是完整的和高质量的。所有对需求的看法是一致的。所有对需求的看法是一致的。需求为继续进行产品设计、构造和测试提供了需求为继续进行产品设计、构造和测试提供了足够的基础。足够的基础。需求验证确保了需求符合需求陈述(需求验证确保了需求符合需求陈述(requirement statement)的良好特征(完)的良好特征(完整的、正确的、灵活的、必要的、具有优整的、正确的、灵活的、必要的、具有优先级的、无二义性及可验证的)并且符合先级的、无二义性及可验证的)并且符合需求规格说明的良好特性(完整的、一致需求规格说明的良好特性(完整的、
6、一致的、易修改的、可跟踪的)。当然,你只的、易修改的、可跟踪的)。当然,你只能验证那些已编写成文档的需求,而那些能验证那些已编写成文档的需求,而那些存在于用户或开发者思维中的没有表露的、存在于用户或开发者思维中的没有表露的、含蓄的需求则不予验证。含蓄的需求则不予验证。需求质量验证在收集需求并编写成需求文档后,你所进行的在收集需求并编写成需求文档后,你所进行的需需求验证求验证并不仅仅是一个独立的阶段。一些验证活并不仅仅是一个独立的阶段。一些验证活动,例如对渐增型软件需求规格说明的反复评审,动,例如对渐增型软件需求规格说明的反复评审,将贯穿着反复获取需求、分析和编写规格说明的将贯穿着反复获取需求、
7、分析和编写规格说明的整个过程。其它的验证步骤,例如软件需求规格整个过程。其它的验证步骤,例如软件需求规格说明的正式审查,是在正式确定软件需求规格说说明的正式审查,是在正式确定软件需求规格说明基线之前对需求分析质量进行的最后一次有用明基线之前对需求分析质量进行的最后一次有用的质量过滤。当你的项目计划或实际工作中的独的质量过滤。当你的项目计划或实际工作中的独立任务破坏了结构性时,就要结合进行需求验证立任务破坏了结构性时,就要结合进行需求验证活动,并且为随后出现的返工预先安排一段时间,活动,并且为随后出现的返工预先安排一段时间,这通常会在质量控制活动之后进行。这通常会在质量控制活动之后进行。需求质量
8、验证有时,项目的参与者不愿意在评审和测试软件需有时,项目的参与者不愿意在评审和测试软件需求规格说明上花费时间。虽然在计划安排中插入求规格说明上花费时间。虽然在计划安排中插入一段时间来提高需求质量似乎相应地把交付日期一段时间来提高需求质量似乎相应地把交付日期延迟了一段时间,但是这种想法是建立在假设验延迟了一段时间,但是这种想法是建立在假设验证需求上的投资将不产生效果的基础上的。实际证需求上的投资将不产生效果的基础上的。实际上,这种投资可以减少返工并加快系统测试,从上,这种投资可以减少返工并加快系统测试,从而真正缩短了开发时间。而真正缩短了开发时间。需求质量验证ValidationAnswer t
9、he question“Do I build the right thing?”Requirements validation is done either against real-world user needs or high level requirements specificationsVerificationAnswer the question“Do I build what I was going to build?”Requirements verification is done typically against lower level requirements,des
10、ign and/or test procedures需求评审由一些非软件开发人员进行产品检查以发由一些非软件开发人员进行产品检查以发现产品所存在的问题,这就是技术评审。现产品所存在的问题,这就是技术评审。需求文档的评审是一项精益求精的技术,需求文档的评审是一项精益求精的技术,它可以发现那些二义性的或不确定的需求,它可以发现那些二义性的或不确定的需求,那些由于定义不清而不能作为设计基础的那些由于定义不清而不能作为设计基础的需求,还有那些实际上是设计规格说明的需求,还有那些实际上是设计规格说明的所谓的所谓的“需求需求”。需求评审也为风险承担者们提供了在特定需求评审也为风险承担者们提供了在特定问题上
11、达成共识的方法。问题上达成共识的方法。需求评审方法非正式评审的方法包括把工作产品分发给许多其非正式评审的方法包括把工作产品分发给许多其它的开发人员粗略看一看和走过场似地检查一遍它的开发人员粗略看一看和走过场似地检查一遍(walkthrough)。)。正式技术评审的最好类型叫作审查正式技术评审的最好类型叫作审查(Inspection)。正式评审内容需要记录在案,)。正式评审内容需要记录在案,它包括确定材料、评审员、评审小组对产品是否它包括确定材料、评审员、评审小组对产品是否完整或是否需要进一步工作的判定,以及对所发完整或是否需要进一步工作的判定,以及对所发现的错误和所提出的问题的总结。正式评审小
12、组现的错误和所提出的问题的总结。正式评审小组的成员对评审的质量负责,而开发者则最终对他的成员对评审的质量负责,而开发者则最终对他们所开发的产品的质量负责。们所开发的产品的质量负责。如果你对提高软件的质量持有认真的态度,那么如果你对提高软件的质量持有认真的态度,那么就审查所编写需求文档的每一行。就审查所编写需求文档的每一行。Software Requirement ReviewInformal reviewPeer desk checkPass around,such as through emailWalk throughFormal reviewsFagan inspection-used
13、by many organization as an effective way to improve software qualityPeer Review需求审查过程需求审查过程1.参与者参与者产品的开发者及其可能的同组成员产品的开发者及其可能的同组成员编写需求文档编写需求文档的分析员提供这方面观点。的分析员提供这方面观点。先前产品的开发者或正在评审的项目的规格说明编写先前产品的开发者或正在评审的项目的规格说明编写者。者。要根据正在审查的文档来开展工作的人们要根据正在审查的文档来开展工作的人们-对于一对于一个软件需求规格说明,你可能需要包括一个开发人员、个软件需求规格说明,你可能需要包括一
14、个开发人员、一个测试人员、一个项目经理和一个用户文档编写人一个测试人员、一个项目经理和一个用户文档编写人员,他们的工作基础都是软件需求规格说明。这些审员,他们的工作基础都是软件需求规格说明。这些审查人员将会发现不同类型的问题。查人员将会发现不同类型的问题。审查组中的审查人员应限制在审查组中的审查人员应限制在7个人左右或者更少。个人左右或者更少。需求审查过程需求审查过程2.审查中每个成员扮演的角色审查中每个成员扮演的角色作者。作者创建或维护正在被审查的产品。作者。作者创建或维护正在被审查的产品。调解者。调解者(调解者。调解者(moderator)或者审查主)或者审查主持者所做的是:与作者一起为审
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件 需求 工程 09 634378
限制150内