软件工程与实践 第2章 软件生命周期与开发模型.ppt
《软件工程与实践 第2章 软件生命周期与开发模型.ppt》由会员分享,可在线阅读,更多相关《软件工程与实践 第2章 软件生命周期与开发模型.ppt(41页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第第2 2章章 软件生命周期与开发模型软件生命周期与开发模型2.1 软件生命周期软件生命周期 软件生存周期一般划分为三个阶段:软件生存周期一般划分为三个阶段:(1)计划时期;)计划时期;(2)开发时期;开发时期;(3)运行与维护时期。运行与维护时期。2.1.1计划时期计划时期这个时期的任务是:这个时期的任务是:(1 1)确定软件开发工程必须完成的总目标;)确定软件开发工程必须完成的总目标;(2 2)确定工程的可行性;)确定工程的可行性;(3 3)导出实现工程目标应该采用的策略及软件)导出实现工程目标应该采用的策略及软件必须具有的功能;必须具有的功能;(4 4)估算完成该项开发工程需要的资源和成
2、本,)估算完成该项开发工程需要的资源和成本,并且制定工程进度表。并且制定工程进度表。可行性研究的步骤一般有如下几个步骤:1关键人员访谈:可行性研究分析人员找到项目干系人中的关键人员,了解如下几方面的内容:(1)项目的规模有多大;(2)项目目标是什么;(3)目前系统的信息来源于何处;(4)目前系统的优点和缺点;(5)目前系统与国内外同类产品的比较,优势和劣势分别是什么。2找出逻辑模型:3找出多种方案。4写出可行性研究报告。5写出需求分析报告。6进行审查。2.1.2 开发时期开发时期一个软件的开发包括四个步骤:一个软件的开发包括四个步骤:(1)需求分析;)需求分析;(2)概要设计;)概要设计;(3
3、)详细设计;)详细设计;(4)编码和测试。这两个过程是)编码和测试。这两个过程是同步进行的。同步进行的。2.1.3 运行与维护时期运行与维护时期软件的维护一般包括改正性维护、适应性维护、完善性维护和预防性维护等四个方面。2.2 软件开发方法综述软件开发方法综述2.2.1 2.2.1 结构化方法结构化方法 结构化开发方法是由E.Yourdon 和 L.L.Constantine 提出的,即所谓的SASD 方 法,也可称为面向功能的软件开发方法或面向数据流的软件开发方法。Yourdon方法是80年代 使用最广泛的软件开发方法。它首先用结构化分析(SA)对软件进行需求分析,然后用结构化设计(SD)方
4、法进行总体设计,最后是结构化编程(SP)。它给出了两类典型的软件结构(变换型和事务型)使软件开发的成功率大大提高。2.2.2 面向数据结构的软件开发方法面向数据结构的软件开发方法 Jackson方法是最典型的面向数据结构的软件开发方法,Jackson方法把问题分解为可由三种基本结构形式表示的各部分的层次结构。三种基本的结构形式就是顺序、选择和重复。三种数据结构可以进行组合,形成复杂的结构体系。这一方法从目标系统的输入、输出数据结构入手,导出程序框架结构,再补充其它细节,就可得到完整的程序结构图。2.2.3 面向问题的分析法(面向问题的分析法(PAM)面向问题的分析法(面向问题的分析法(PAM,
5、Problem Analysis Method)是)是80年代末由日立公年代末由日立公司提出的一种软件开发方法。司提出的一种软件开发方法。它的基本思它的基本思想是考虑到输入、输出数据结构,指导系想是考虑到输入、输出数据结构,指导系统的分解,在系统分析指导下逐步综统的分解,在系统分析指导下逐步综 合。合。这一方法的具体步骤是:从输入、输这一方法的具体步骤是:从输入、输出数据结构导出基本处理框;分析这些处出数据结构导出基本处理框;分析这些处理框之间的先后关系;按先后关系逐步综理框之间的先后关系;按先后关系逐步综合处理框,直到画出整个系统的合处理框,直到画出整个系统的PAD图图2.2.4 面向对象的
6、开发方法面向对象的开发方法面向对象系统采用了自底向上的归纳、自顶向下的分解的方法,它通过对对象模型的建立,能够真正建立基于用户的需求,而且系统的可维护性大大改善。当前业界关于面向对象建模的标准是UML.2.2.5、原型化方法、原型化方法 产生原型化方法的原因很多,主要随着我们系统开发经验的增多,我们也发现并非所有的需求都能够预先定义而且反复修改是不可避免的。当然能够采用原型化方法是因为开发工具的快速发展,比如用VB,DELPHI等工具我们可以迅速的开发出一个可以让用户看的见、摸的着的系统框架,这样,对于计算机不是很熟悉的用户就可以根据这个样板提出自己的需求。2.2.6 可视化开发方法可视化开发
7、方法 可视化开发并不能单独的作为一种开发方法,更加贴切的说可以认为它是一种辅助工具,比如:S-Design,PowerDesigner,PowerBuilder,VB,DELPHI,C+Builder等。2.3 软件开发模型软件开发模型2.3.1 2.3.1 瀑布模型瀑布模型 将将软软件件生生命命周周期期划划分分为为制制定定计计划划、需需求求分分析析、软软件件设设计计、程程序序编编写写、软软件件测测试试和和运运行行维维护护等等六六个个基基本本活活动动,并并且且规规定定了了它它们们自自上上而而下下、相相互互衔衔接接的的固固定定次次序序,如如同同瀑瀑布布流流水,逐级下落。水,逐级下落。2.3.2
8、螺旋模型螺旋模型 螺旋模型沿着螺线进行若干次迭代,图螺旋模型沿着螺线进行若干次迭代,图2-52-5中的四个象限代表了以中的四个象限代表了以下活动下活动.螺旋模型沿着螺线旋转,每个螺旋推进的过程都是渐进的实现螺旋模型沿着螺线旋转,每个螺旋推进的过程都是渐进的实现过程,整个过程的实现,按照过程,整个过程的实现,按照”制定计划、风险分析、实施工程和客户制定计划、风险分析、实施工程和客户评估评估”四个步骤循环实施。四个步骤循环实施。(1 1)制定计划:确定软件目标,选定实施方案,弄清项目开发的)制定计划:确定软件目标,选定实施方案,弄清项目开发的限制条件。定义资源、进度及其他相关项目信息所需要的任务,
9、以调整限制条件。定义资源、进度及其他相关项目信息所需要的任务,以调整项目的目标和改善系统实施的效率。项目的目标和改善系统实施的效率。(2 2)风险分析:分析评估所选方案,考虑如何识别和消除风险。风险分析:分析评估所选方案,考虑如何识别和消除风险。从风险角度分析方案的开发策略,努力排除各种潜在的风险,有时需要从风险角度分析方案的开发策略,努力排除各种潜在的风险,有时需要通过建造原型来完成。如果某些风险不能排除,该方案立即终止,否则通过建造原型来完成。如果某些风险不能排除,该方案立即终止,否则启动下一个开发步骤。基于上述目标,评估技术及管理的风险,以决定启动下一个开发步骤。基于上述目标,评估技术及
10、管理的风险,以决定如何实施项目。如何实施项目。(3 3)实施工程:实施软件开发和验证。包括系统需求分析、概要实施工程:实施软件开发和验证。包括系统需求分析、概要设计、详细设计、编程、单元测试、系统测试和验证测试等项目具体实设计、详细设计、编程、单元测试、系统测试和验证测试等项目具体实施的各种任务。施的各种任务。(4(4)客户评估:评价开发工作,提出修正建议,制定下一步计划。客户评估:评价开发工作,提出修正建议,制定下一步计划。螺旋模型的缺点是:螺旋模型的缺点是:(1)(1)它可能难以使用户它可能难以使用户相信演化方法是可控的;相信演化方法是可控的;(2 2)瀑布模型要求在软件开发的初期就完全确
11、定软)瀑布模型要求在软件开发的初期就完全确定软件的需求,这在很多情况下往往是无法实现的。螺旋模件的需求,这在很多情况下往往是无法实现的。螺旋模型加入了瀑布模型所忽略的风险分析,从而弥补了瀑布型加入了瀑布模型所忽略的风险分析,从而弥补了瀑布模型的不足。模型的不足。螺旋模型也有一定的限制条件,这些限制条件是:螺旋模型也有一定的限制条件,这些限制条件是:1 1)螺旋模型强调风险分析,但要求许多客户接受和)螺旋模型强调风险分析,但要求许多客户接受和相信这种分析,并做出相关反应是不容易的,因此,这相信这种分析,并做出相关反应是不容易的,因此,这种模型往往适应于内部的大规模软件开发。种模型往往适应于内部的
12、大规模软件开发。2 2)如果执行风险分析将大大影响项目的利润,那如果执行风险分析将大大影响项目的利润,那么进行风险分析毫无意义,因此,螺旋模型只适合于大么进行风险分析毫无意义,因此,螺旋模型只适合于大规模软件项目。规模软件项目。3 3)软件开发人员应该擅长寻找可能的风险,准确软件开发人员应该擅长寻找可能的风险,准确地分析风险,否则将会带来更大的风险。地分析风险,否则将会带来更大的风险。2.3.3 增量模型增量模型 增量模型和瀑布模型之间的本质区别是:增量模型和瀑布模型之间的本质区别是:瀑布模型属于整体开发模型,它规定在开始下一瀑布模型属于整体开发模型,它规定在开始下一个阶段的工作之前,必须完成
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件工程与实践 第2章 软件生命周期与开发模型 软件工程 实践 软件 生命周期 开发 模型
限制150内