版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1SoftwareRequirementsEngineering
软件需求工程
郑州大学软件学院软件工程专业必修课程授课对象:本科3年级授课教师:徐强11SoftwareRequirementsEnginee需求开发向设计规划的转化22需求开发向设计规划的转化22本章内容从需求到项目规划从需求到设计和编码从需求到测试从需求到成功33本章内容从需求到项目规划33从需求到项目规划由于需求定义了项目的预期成果,所以项目规划、项目预算和项目的进度安排都必须以软件需求为基础。最重要的项目成果是交付满足业务目标的系统,而不一定是根据最初的项目规划实现所有初始需求的系统。需求和规划只代表团队最初的评估,项目成果就是根据这一评估来完成的。下表说明对需求工作的投资可以加速项目的开发。需求阶段投入的工作量需求阶段投入的时间开发较快的项目
14%
17%
开发较慢的项目
7%
9%
44从需求到项目规划由于需求定义了项目的预期成果,所以项目规划、需求和进度安排许多软件工程实行“从右到左的进度安排”,此时,规定了发行产品的具体日期而后定义产品的需求。当开发者要实现预期质量标准下所有要求的功能时,他们常常不能按时完成项目。在做出详细的规划和约定之前定义软件需求是更现实的。然而,如果你在需求的哪些部分能适应进度安排的限制哪些部分不能适应进度安排的限制这一问题上还有商量余地的话,那么“从设计到进度安排”的策略是可以起作用的。对于复杂的系统,软件仅是最终产品的一部分时,只有在产品级(系统)需求产生以后,才能建立高层的进度安排。55需求和进度安排许多软件工程实行“从右到左的进度安排”,此时,需求和进度安排可能考虑按阶段规划和提供项目资金。需求探索作为第一阶段将提供足够的信息,使你能为一个或更多的构造阶段进行现实的规划和预测。具有不确定需求的项目也可以从反复或渐增的软件开发生存期中得以改善。定义需求的优先级可以使你判断出哪些功能应包括在首发版中,哪些功能放到随后发行的版本中。66需求和进度安排可能考虑按阶段规划和提供项目资金。66需求和进度安排主要的规划失误包括:忽略公共(用)的项目任务,低估了要花费的工作量和时间,没有考虑项目风险,并且没有考虑返工所需的时间。正确的项目规划需要以下元素:根据对需求的清楚理解来估计产品规模的大小。根据历史记录了解开发小组的工作效率。一张综合的任务列表以完整实现和验证每一特性或使用实例。有效的预测和规划过程。经验(这有助于项目经理对不可触及的因素和每一个项目所特有的因素加以调整)。注意:不要迫于压力而许下自己明知道不可能做到的诺言,这是避免最后两败俱伤的秘诀。
77需求和进度安排主要的规划失误包括:忽略公共(用)的项目任务,需求和预估项目估计(预估)的第一步就是要把需求和软件产品规模的大小相联系。你可以根据文本需求、图形分析模型、原型或用户界面设计来预估产品的大小。虽然对于软件大小没有完善的度量标准,但以下给出了一些常用的度量标准:功能点和特性点的多少,或者将数据、功能和控制三者整合在一起的三维功能点的数量。图形用户界面(GUI)元素的数量、类型和复杂度。用于实现特定需求所需的源代码行数。对象类的数量或者其它面向对象系统的衡量标准。单个可测试需求的数量。88需求和预估项目估计(预估)的第一步就是要把需求和软件产品规模需求和预估含糊的和不确定的需求必定会引起你在软件大小预估中的不确定性,从而导致你的工作量和进度安排预估的不确定。在项目的早期阶段,需求的不确定性是不可避免的,所以在进度安排中应包括临时的事件并要合理预算资金以适应一些需求的增加和可能的超限。开发时间与产品大小或开发小组的大小没有线性关系。在产品大小、工作量、开发时间、生产率和人员技术积累时间之间是存在着复杂的关系。理解这种关系可以防止你陷入进度安排或人员任务安排承诺的误区。99需求和预估含糊的和不确定的需求必定会引起你在软件大小预估中的本章内容从需求到项目规划从需求到设计和编码从需求到测试从需求到成功1010本章内容从需求到项目规划1010从需求到设计和编码需求和设计之间存在差别,但尽量使你的规格说明的具体实现无倾向性。需求开发和规格说明应该强调对预期系统外部行为的理解和描述。让设计者和开发者参与需求审查以判断需求是否可以作为设计的基础。如果直接从需求规格说明跳到编码阶段,你所设计的软件将会是空中阁楼,其可能的结果只能是结构性很差的一个软件。在构造软件之前,应该仔细考虑构造系统的最有效的方法。设计上的返工比编码返工可能要效率高一些。1111从需求到设计和编码需求和设计之间存在差别,但尽量使你的规格说从需求到设计和编码产品的需求、质量属性和用户特点可以决定产品体系结构。对于同时包括软件组件和硬件组件的系统,以及只包括软件的复杂系统,体系结构就显得尤其关键。将系统功能分配给子系统或组件必须采用自顶向下的方法。在开始实现产品之前,虽然不需要为整个产品开发完整的、详细的设计,但是,应该先对每一个组件进行设计,然后再对其进行编码。设计规划将有益于大难度项目(有许多内部组件接口和交互作用的系统和开发人员无经验的项目)。1212从需求到设计和编码产品的需求、质量属性和用户特点可以决定产品从需求到设计和编码下面介绍的步骤将有益于所有的项目:为子系统和组件开发一个坚固的体系结构,这一体系结构在产品改进的过程中可以保持不变。确定需要构建的主要对象类或功能模块,定义它们的接口、职责以及与其他单元的协作。对并行处理系统,要理解计划的执行线程或对并发进程的功能分配。根据强内聚、低耦合和信息隐藏等这些良好的设计原则,定义每个代码单元的预期功能。确保设计满足所有的功能性需求,但不要包括不必要的功能。确保设计能适应可能出现的异常条件。确保设计能达到所陈述的性能、健壮性、可靠性和其他一些质量属性的目标。1313从需求到设计和编码下面介绍的步骤将有益于所有的项目:1313从需求到设计和编码当开发者把需求转化为设计和代码时,他们将会遇到不确定和混淆的地方。理想情况下,开发者可沿着发生的问题回溯至客户并获得解决方案。如果不能马上解决问题,那么开发者所做出的任何假设,猜想或解释都要编写成文档记录下来,并由客户代表评审。1414从需求到设计和编码当开发者把需求转化为设计和代码时,他们将会本章内容从需求到项目规划从需求到设计和编码从需求到测试从需求到成功1515本章内容从需求到项目规划1515从需求到测试详尽的需求是系统测试的基础。必须针对软件需求规格说明中所记录的产品的预期行为来测试整个软件,而不是针对设计或编码。产品可以正确呈现基于代码的测试用例所描述的所有行为,但这并不意味着产品正确地实现了用户的需求。让测试人员参与需求审查以确保需求是明确的,通过验证的需求才可以作为系统测试的基础。1616从需求到测试详尽的需求是系统测试的基础。1616从需求到测试在需求开发中,当每个需求都稳定之后,项目的系统测试人员应该编写文档,以记录他们如何验证需求—通过测试、审查,演示或分析。对如何验证每一需求的思考过程本身就是一种很有用的质量审查实践。根据需求中的逻辑描述,利用诸如因果图等分析技术来获得测试用例,这将会揭示需求的二义性、遗漏或隐含的其它条件和其它问题。在系统测试方案中,每个需求应至少由一个测试用例来测试,这样就会验证所有的系统行为。可以由跟踪通过测试的需求所占的比例来衡量测试进度。1717从需求到测试在需求开发中,当每个需求都稳定之后,项目的系统测从需求到测试基于规格说明的测试适用于许多测试设计策略:动作驱动数据驱动(包括边界值分析和等价类的划分)逻辑驱动事件驱动状态驱动从正式的规格说明中很容易自动生成测试用例,但是对于更多的由自然语言描述的需求规格说明,必须手工开发测试用例。比起结构化分析图,对象模型更易于自动生成测试用例。1818从需求到测试基于规格说明的测试适用于许多测试设计策略:181从需求到测试在开发的进展过程中,你将通过详细的软件功能需求仔细推敲来自使用实例高层抽象的需求,并最终转化成单个代码模块的规格说明。针对需求的测试必须在软件结构的每一层进行,而不只是在用户层进行。在一个应用程序中有许多代码不会被用户所访问,但这些代码却是产品基础操作所需要的。即使有些模块功能在整个软件产品中对用户都不可见,但是每个模块功能必须满足其自身的需求或规格说明要求。针对用户需求来测试系统是系统测试的必要但非充分条件。1919从需求到测试在开发的进展过程中,你将通过详细的软件功能需求仔本章内容从需求到项目规划从需求到设计和编码从需求到测试从需求到成功2020本章内容从需求到项目规划2020从需求到成功使项目更成功的一种方法是,列出与特定的代码版本相对应的所有需求。项目的质量保证(qualityassurance,QA)小组通过对照相应的需求来执行测试,从而对每一个版本进行评估。这个项目的成功,在很大程度上得益于根据需求文档来决定何时发布产品。软件开发项目最终的可交付工件应该是一个满足客户需要和期望的软件系统。需求是从业务需要通向用户满意之路中必不可少的一步。努力在精确的规格说明与可将产品失败的风险降至可接受程度的编码之间做出明智的选择。2121从需求到成功使项目更成功的一种方法是,列出与特定的代码版本相22SoftwareRequirementsEngineering
软件需求工程
郑州大学软件学院软件工程专业必修课程授课对象:本科3年级授课教师:徐强221SoftwareRequirementsEnginee需求开发向设计规划的转化2323需求开发向设计规划的转化22本章内容从需求到项目规划从需求到设计和编码从需求到测试从需求到成功2424本章内容从需求到项目规划33从需求到项目规划由于需求定义了项目的预期成果,所以项目规划、项目预算和项目的进度安排都必须以软件需求为基础。最重要的项目成果是交付满足业务目标的系统,而不一定是根据最初的项目规划实现所有初始需求的系统。需求和规划只代表团队最初的评估,项目成果就是根据这一评估来完成的。下表说明对需求工作的投资可以加速项目的开发。需求阶段投入的工作量需求阶段投入的时间开发较快的项目
14%
17%
开发较慢的项目
7%
9%
2525从需求到项目规划由于需求定义了项目的预期成果,所以项目规划、需求和进度安排许多软件工程实行“从右到左的进度安排”,此时,规定了发行产品的具体日期而后定义产品的需求。当开发者要实现预期质量标准下所有要求的功能时,他们常常不能按时完成项目。在做出详细的规划和约定之前定义软件需求是更现实的。然而,如果你在需求的哪些部分能适应进度安排的限制哪些部分不能适应进度安排的限制这一问题上还有商量余地的话,那么“从设计到进度安排”的策略是可以起作用的。对于复杂的系统,软件仅是最终产品的一部分时,只有在产品级(系统)需求产生以后,才能建立高层的进度安排。2626需求和进度安排许多软件工程实行“从右到左的进度安排”,此时,需求和进度安排可能考虑按阶段规划和提供项目资金。需求探索作为第一阶段将提供足够的信息,使你能为一个或更多的构造阶段进行现实的规划和预测。具有不确定需求的项目也可以从反复或渐增的软件开发生存期中得以改善。定义需求的优先级可以使你判断出哪些功能应包括在首发版中,哪些功能放到随后发行的版本中。2727需求和进度安排可能考虑按阶段规划和提供项目资金。66需求和进度安排主要的规划失误包括:忽略公共(用)的项目任务,低估了要花费的工作量和时间,没有考虑项目风险,并且没有考虑返工所需的时间。正确的项目规划需要以下元素:根据对需求的清楚理解来估计产品规模的大小。根据历史记录了解开发小组的工作效率。一张综合的任务列表以完整实现和验证每一特性或使用实例。有效的预测和规划过程。经验(这有助于项目经理对不可触及的因素和每一个项目所特有的因素加以调整)。注意:不要迫于压力而许下自己明知道不可能做到的诺言,这是避免最后两败俱伤的秘诀。
2828需求和进度安排主要的规划失误包括:忽略公共(用)的项目任务,需求和预估项目估计(预估)的第一步就是要把需求和软件产品规模的大小相联系。你可以根据文本需求、图形分析模型、原型或用户界面设计来预估产品的大小。虽然对于软件大小没有完善的度量标准,但以下给出了一些常用的度量标准:功能点和特性点的多少,或者将数据、功能和控制三者整合在一起的三维功能点的数量。图形用户界面(GUI)元素的数量、类型和复杂度。用于实现特定需求所需的源代码行数。对象类的数量或者其它面向对象系统的衡量标准。单个可测试需求的数量。2929需求和预估项目估计(预估)的第一步就是要把需求和软件产品规模需求和预估含糊的和不确定的需求必定会引起你在软件大小预估中的不确定性,从而导致你的工作量和进度安排预估的不确定。在项目的早期阶段,需求的不确定性是不可避免的,所以在进度安排中应包括临时的事件并要合理预算资金以适应一些需求的增加和可能的超限。开发时间与产品大小或开发小组的大小没有线性关系。在产品大小、工作量、开发时间、生产率和人员技术积累时间之间是存在着复杂的关系。理解这种关系可以防止你陷入进度安排或人员任务安排承诺的误区。3030需求和预估含糊的和不确定的需求必定会引起你在软件大小预估中的本章内容从需求到项目规划从需求到设计和编码从需求到测试从需求到成功3131本章内容从需求到项目规划1010从需求到设计和编码需求和设计之间存在差别,但尽量使你的规格说明的具体实现无倾向性。需求开发和规格说明应该强调对预期系统外部行为的理解和描述。让设计者和开发者参与需求审查以判断需求是否可以作为设计的基础。如果直接从需求规格说明跳到编码阶段,你所设计的软件将会是空中阁楼,其可能的结果只能是结构性很差的一个软件。在构造软件之前,应该仔细考虑构造系统的最有效的方法。设计上的返工比编码返工可能要效率高一些。3232从需求到设计和编码需求和设计之间存在差别,但尽量使你的规格说从需求到设计和编码产品的需求、质量属性和用户特点可以决定产品体系结构。对于同时包括软件组件和硬件组件的系统,以及只包括软件的复杂系统,体系结构就显得尤其关键。将系统功能分配给子系统或组件必须采用自顶向下的方法。在开始实现产品之前,虽然不需要为整个产品开发完整的、详细的设计,但是,应该先对每一个组件进行设计,然后再对其进行编码。设计规划将有益于大难度项目(有许多内部组件接口和交互作用的系统和开发人员无经验的项目)。3333从需求到设计和编码产品的需求、质量属性和用户特点可以决定产品从需求到设计和编码下面介绍的步骤将有益于所有的项目:为子系统和组件开发一个坚固的体系结构,这一体系结构在产品改进的过程中可以保持不变。确定需要构建的主要对象类或功能模块,定义它们的接口、职责以及与其他单元的协作。对并行处理系统,要理解计划的执行线程或对并发进程的功能分配。根据强内聚、低耦合和信息隐藏等这些良好的设计原则,定义每个代码单元的预期功能。确保设计满足所有的功能性需求,但不要包括不必要的功能。确保设计能适应可能出现的异常条件。确保设计能达到所陈述的性能、健壮性、可靠性和其他一些质量属性的目标。3434从需求到设计和编码下面介绍的步骤将有益于所有的项目:1313从需求到设计和编码当开发者把需求转化为设计和代码时,他们将会遇到不确定和混淆的地方。理想情况下,开发者可沿着发生的问题回溯至客户并获得解决方案。如果不能马上解决问题,那么开发者所做出的任何假设,猜想或解释都要编写成文档记录下来,并由客户代表评审。3535从需求到设计和编码当开发者把需求转化为设计和代码时,他们将会本章内容从需求到项目规划从需求到设计和编码从需求到测试从需求到成功3636本章内容从需求到项目规划1515从需求到测试详尽的需求是系统测试的基础。必须针对软件需求规格说明中所记录的产品的预期行为来测试整个软件,而不是针对设计或编码。产品可以正确呈现基于代码的测试用例所描述的所有行为,但这并不意味着产品正确地实现了用户的需求。让测试人员参与需求审查以确保需求是明确的,通过验证的需求才可以作为系统测试的基础。3737从需求到测试详尽的需求是系统测试的基础。1616从需求到测试在需求开发中,当每个需求都稳定之后,项目的系统测试人员应该编写文档,以记录他们如何验证需求—通过测试、审查,演示或分析。对如何验证每一需求的思考过程本身就是一种很有用的质量审查实践。根据需求中的逻辑描述,利用诸如因果图等分析技术来获得测试用例,这将会揭示需求的二义性、遗漏或隐含的其它条件和其它问题。在系统测试方案中,每个需求应至少由一个测试用例来测试,这样就会验证所有的系统行为。可以由跟踪通过测试的需求所占的比例来衡量测试进度。38
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024木工班组劳务承包合同范文
- 2025年九江货运从业资格证在哪里练题
- 2024机器设备空运出口运输合同
- 2024电信营业厅装修合同样本
- 二零二五年度坚果产业科技创新与应用合同3篇
- 2025年度智慧城市物业房屋租赁三方合同(含智能化服务)3篇
- 2025年鲁科五四新版六年级英语下册阶段测试试卷
- 2024年湘师大新版八年级物理上册月考试卷
- 2025年度文化艺术品鉴赏与拍卖合同
- 2025年鲁教版选修1化学下册月考试卷
- 化工(危险化学品)企业主要负责人、安管员安全生产管理专项培训考核试卷(附参考答案)
- 中华人民共和国残疾评定表
- 人教版美术五年级上册《第2课 色彩的和谐》说课稿2
- 2024年6月浙江省高考历史试卷(真题+答案)
- 住友(SWS)汽车连接器(Connectors)产品配套手册
- 办公楼室内装饰工程施工设计方案技术标范本
- 2023年香港华夏杯六年级竞赛初赛数学试卷
- 高中数学放缩法
- 上海市闵行区2024-2025学年八年级(上)期末物理试卷(解析版)
- 2024年国考行测真题-言语理解与表达真题及完整答案1套
- 人教版三年级上册数学期末测试卷可打印
评论
0/150
提交评论