《软件工程2ppt课件.ppt》由会员分享,可在线阅读,更多相关《软件工程2ppt课件.ppt(31页珍藏版)》请在三一办公上搜索。
1、,第2章 软件过程,l软件开发过程是一个将用户需求转化为软件系统所需要的 活动的集合lISO9000把过程定义为:“把输入转化为输出的一组彼此相关的资源和活动”l软件过程定义了运用方法的顺序、应该交付的文档资料、为保证软件质量和协调变化所需要采取的管理措施以及 标志软件开发各个阶段任务完成的里程碑。,2.1 软件生命周期的基本任务2.2 软件过程模型2.3 微软的软件过程第2章 思考题,1.软件生命周期:一个软件从定义、开发、运行维护,直到最终被 废弃要经历一个漫长的时期,这个时期称为软件生命 周期。,2.软件生命周期的组成阶段及任务 软件定义时期,(1)问题定义阶段:通过调研,提出关于问题的
2、性质、工程目标和 工程规模的书面报告,并且需要得到客户的确认。回答“要解决的问题是什么?”文档:问题定义报告,(2)可行性研究阶段:用最小的代价在尽可能短的时间内确定问题 是否能够解决。,进一步了解用户需求 提出若干种可能的系统实现方案 分析每种方案的技术、经济、社会可行性 最终确定这项工程的可行性,回答“是否有行得通的解决方法?”文档:可行性研究报告,项目开发计划,(3)需求分析阶段:对目标系统提出完整、准确、清晰、具体的要求。,得出经过用户确认的系统需求 用正式文档(需求规格说明)准确表达系统需求,l回答“系统必须做什么?”l文档:需求分析规格说明书,软件开发时期,(4)概要设计阶段:设计
3、系统实现方案 设计程序的体系结构,即确定程序由哪些模块 组成以及模块间的关系。l 概括地回答“怎样实现目标系统?”l文档:概要设计说明书,(5)详细设计阶段:设计实现每个模块功能所需要的算 法和数据结构 l回答“应该怎样具体地实现这个系统?”l文档:详细设计说明书,(6)编码和单元测试:写出正确的、易理解、易维护的程序模块代码;测试编写出的每一个模块 l文档:经过测试的程序源代码、程序开发记录(模块开发卷宗),(7)综合测试阶段:通过各种类型的测试(及相应的调试)使软件达到预定的要求。集成测试(组装测试)。验收测试 l 测试文档:测试计划、详细测试方案、实际测试结果,软件运行维护时期,(8)软
4、件维护阶段:通过各种必要的维护活动使系统持久地满足 用户的需要。,l四类维护活动:改正性维护、适应性维护、完善性维护、预防性维护l文档:软件维护申请、软件修改报告,l软件生命周期模型也称为软件过程模型,它直观地 描述了把软件生命周期划分成哪些阶段及各个阶段 的执行顺序,l经典模型:瀑布模型,快速原型模型;增量模型,螺旋模型;喷泉模型 l现代模型:RUP模型 l敏捷过程:极限编程,SCRUM,2.2.1 瀑布模型2.2.2 快速原型模型2.2.3 增量模型2.2.4 螺旋模型2.2.5 喷泉模型2.2.6 Rational统一过程2.2.7 敏捷过程与极限编程,属于演化模型;强调软件是建造出来
5、的,不是写出来的,(1)瀑布模型,(2)瀑布模型的特点 阶段间具有顺序性和依赖性 推迟实现的观点 阶段质量保证观点(文档驱动),l优点:强迫采用规范方法开发软件;严格规定了各阶段提交的文档;各阶段结束前必须经过技术审查和管理复审。,l缺点:分析和设计阶段只考虑逻辑模型;过分依赖文档,可能导致最终的软件产品不能完全满足用户需求。,理想的瀑布模型,实际的瀑布模型,(1)快速原型模型的含义:快速建立一个能反映用户主要需求的可执行系统,让用 户试用,根据用户意见进行修改,从而了解真正的用户 需求;,(2)快速原型模型的优点:通过原型获得准确的用户需求;通过原型积累了开发经 验,软件开发时期的各阶段基本
6、上是线性顺序过程、提 高了总开发效率。,快速原型模型,(1)增量模型的含义:把软件产品看成由一系列构件组成;每个构件由若干 个相互作用的模块组成,并且能够完成特定的功能。,l增量模型的技术难点:软件体系结构必须是开放的,(2)增量模型的优点:便于并行完成开发工作;逐步提交软件产品;软件的可维护性和可扩充性较好。,l螺旋模型是一个演化的软件过程模型,是在每个阶段之 前都增加了风险分析过程的快速原型模型。l在螺旋模型中,螺旋线的每个周期对应一个软件生命周 期的开发阶段。每个阶段包括四个方面的活动:制定计划-确定目标,选定方案,设定约束条件 风险评估-评估所选方案,识别风险,考虑如何消除风险 实施工
7、程 评估工程-评价开发工作,提出修正建议。,l使用螺旋模型需要丰富的风险评估经验和专门知识;l螺旋模型适用于内部开发的大型软件项目,l喷泉模型也称为面向对象的生命周期模型l软件开发过程阶段之间是迭代的、无缝的l在分析、设计和编码等开发活动之间并不 存在明显的边界,lRUP模型(RUP,Rational统一过程,rational unified process),lRUP融入了瀑布模型的线性结构和 演化模型的增量和迭代思想,lRUP首先建立整个项目的不同阶段,包括:“初始阶段”,“细化阶段”,“构造阶段”,“移交阶段”同时每个阶段中又保留了瀑布模型的活动:计划、需求、分析与设计到实现、测试,敏捷
8、软件开发宣言的4个简单的价值观声明:(1)“个体和交互”胜过“过程和工具”(2)“可以使用的软件”胜过“面面俱到的文档”(3)“客户合作”胜过“合同谈判”(4)“响应变化”胜过“遵循计划”l对敏捷过程的另一种解读:敏捷软件思想=沟通+简单+反馈+勇气,l敏捷过程,“极限”的含义:把好的开发实践运用到极致,l极限编程(Extreme Programming,XP),极限编程的整体开发过程,增量模型,螺旋模型,RUP 软件开发生命周期,RUP生命周期工作阶段和里程碑,RUP生命周期工作阶段:按时间分成四个顺序阶段,每个阶段以一个主要里程碑 结束;每个阶段的目标通过一次或多次迭代来完成。,RUP的迭代式开发过程,RUP开发过程允许需求变更,l微软软件生命周期,l微软的软件过程模型,l第2章 思考题,1.什么是软件生命周期,分哪几个阶段、各阶段的任务是 什么?2.常用的软件生命周期模型有哪些?总结它们的特点。3.谈谈下列三者之间的区别和联系:软件工程、软件过程、软件生命周期模型,