软件工程课本讲解第7章 增量模型

上传人:无*** 文档编号:245193676 上传时间:2024-10-07 格式:PPT 页数:42 大小:381.50KB
返回 下载 相关 举报
软件工程课本讲解第7章 增量模型_第1页
第1页 / 共42页
软件工程课本讲解第7章 增量模型_第2页
第2页 / 共42页
软件工程课本讲解第7章 增量模型_第3页
第3页 / 共42页
点击查看更多>>
资源描述
,第7章 增量模型,第,7,章 增量模型,7.1 概述,7.2 渐增模型,7.3 快速原型模型,7.4 快速原型的开发技术和开发环境,7.5 增量模型的评价,7.6 小结,习题,习题,1.,渐增模型有几种?各有何特点?,2.,快速原型模型有几种?各有何特点?,3.,快速原型模型的开发步骤是什么?,4.,评价快速原型模型的优缺点。,5.,对比瀑布模型与增量模型,指出增量模型的新思路。,7.1,概述,7.1.1,瀑布模型的局限性,传统的瀑布模型给软件产业带来了巨大的进步,部分地缓解了软件危机,但这种模型本质上是一种线性顺序模型,存在着比较明显的缺点,各阶段之间存在着严格的顺序性和依赖性,特别是强调预先定义需求的重要性,在着手进行具体的开发工作之前,必须通过需求分析预先定义并,“,冻结,”,软件需求,然后再一步一步的实现这些需求。但是实际项目很少是遵循着这种线性顺序进行的。虽然瀑布模型也允许迭代,但这种改变往往对项目开发带来混乱。在系统建立之前很难只依靠分析就确定出一套完整、准确、一致和有效的用户需求,这种预先定义需求的方法更不能适应用户需求不断变化的情况。,1.,需求是可变的,某些应用软件的需求与外部环境、公司经营策略或经营内容等密切相关,因此需求是随时变化的,在不同时间用户的需求可能有较大的不同,采用预先定义整体不变的需求的策略,在一年或数年之前预先指定对需求随时间变化的软件的需求,显然是不切实际的。按照这样预先指定的需求开发软件,当软件开发出来的时候就已经过时了,不符合那时的用户需要了。然而按照瀑布模型开发,在开发后期修改需求要付出很高的代价,甚至根本不可能修改。,2.,需求是模糊的,对于某些类型的软件系统,如操作系统、编译系统等系统软件,人们对它们比较熟悉,有长期使用它们的经验,其需求经过仔细的分析之后可以预先指定。但是,对于大多数经常使用的应用系统,例如管理信息系统,其需求往往很难预先准确的指定,也就是说,预先定义需求的策略所做出的假设,只对某些软件成立,对多数软件并不成立。许多用户对他们的需求最初只有模糊的概念,想要求一个对需求只有初步设想的人准确无误地说出全部需求,显然是不切实际的。人们为了充实和细化他们的初步设想,通常需要经过在某个能运行的系统上进行实践的过程。,3.,用户和开发者难于沟通,大型软件的开发需要系统分析员、软件工程师、程序员、用户和领域专家等各类人员的协同配合。因此良好的通信和相互理解对于保证工程成功是至关重要的。大多数用户和领域专家不熟悉计算机和软件技术,软件开发人员也往往不熟悉用户的专业领域,特别在涉及各种不同领域的知识时,情况更是如此。因此,开发人员和用户之间很难做到完全沟通和相互理解,在需求分析阶段做出的用户需求常常是不完整、不准确的。因此,即使用户签字同意了的需求说明书,也并不能保证根据这份说明书开发出来的软件系统就能真正满足用户的需要。,从以上论述可知,传统的瀑布模型很难适应需求可变、模糊不定的软件系统的开发,而且在开发过程中,用户很难参与进去,只有到开发结束才能看到整个软件系统。这种理想的、线性的开发过程,缺乏灵活性,不适合实际的开发过程。,7.1.2,增量模型的基本思想,为了克服瀑布模型的局限性,使开发过程具有一定的灵活性和可修改性,于是产生了增量模型。它是在瀑布模型的基础上加以修改而形成的。,增量模型和瀑布模型之间的本质区别是:,瀑布模型属于整体开发模型,,它规定在开始下一个阶段的工作之前,必须完成前一阶段的所有细节。而,增量模型属于非整体开发模型,,它推迟某些阶段或所有阶段中的细节,从而较早地产生工作软件。,增量模型是在项目的开发过程中以一系列的增量方式开发系统。,增量方式包括增量开发和增量提交,。增量开发是指在项目开发周期内,以一定的时间间隔开发部分工作软件;增量提交是指在项目开发周期内,以一定的时间间隔增量方式向用户提交工作软件及相应文档。增量开发和增量提交可以同时使用,也可单独使用。,7.1.3,增量模型的分类,有多种增量模型,根据增量的方式和形式的不同,分为,渐增模型和原型模型。,1.,渐增模型,这种模型是瀑布模型的变种,有两类渐增模型:,(1),增量构造模型:是在瀑布模型的基础上,对一些阶段进行整体开发,对另一些阶段进行增量开发。也就是说,在前面的开发阶段按瀑布模型进行整体开发,后面的开发阶段按增量方式开发。,(2),演化提交模型:是在瀑布模型的基础上,所有阶段都进行增量开发,即不仅是增量开发,也是增量提交。,2.,原型模型,这种开发模型又称,快速原型模型,,它是增量模型的另一种形式。它是在开发真实系统之前,构造一个原型,在该原型的基础上,逐渐完成整个系统的开发工作。根据原型的不同作用,有以下三类原型模型:,(1),探索型原型,:其原型模型是把原型用于开发的需求分析阶段,目的是要弄清用户的需求,确定所期望的特性,并探索各种方案的可行性。它主要针对开发目标模糊,用户与开发者对项目都缺乏经验的情况,通过对原型的开发来明确用户的需求。,(2),实验型原型,:主要用于设计阶段,考核实现方案是否合适,能否实现。对于一个大型系统,若对设计方案心中没有把握,可通过这种原型来证实设计方案的正确性。,(3),演化型原型,:主要用于及早向用户提交一个原型系统,该原型系统包含系统的框架,或包含系统的主要功能,在得到用户的认可后,将原型系统不断扩充演变为最终的软件系统。它将原型的思想扩展到软件开发的全过程。,7.2,渐增模型,7.2.1,增量构造模型,增量构造模型如图,7.1,所示。在该模型中,需求分析阶段和设计阶段都是按瀑布模型的整体方式开发的,但是编码阶段和测试阶段是按增量方式开发的。在这种模型的开发中,用户可以及早看到部分软件功能,及早发现问题,以便在开发其他软件功能时及时解决问题。,图7.1 增量构造模型,7.2.2,演化提交模型,演化提交模型如图,7.2,所示。在该模型中,项目开发的各个阶段都是增量方式。先对某部分功能进行需求分析,然后顺序进行设计、编码和测试,把该功能的软件交付给用户,再对另一部分功能进行开发,提交用户直至所有功能全部增量开发完毕为止。开发的顺序按图,7.2,中的编号进行。该模型是增量开发的极端形式,它不仅是增量开发也是增量提交,用户将最早收到部分工作软件,能及早发现问题,使修改扩充更容易。,图7.2 演化提交模型,7.3,快速原型模型,7.3.1,基本思想,1.,原型,原型是指模拟某种产品的,原始模型,,在其他产业中经常使用模型。例如,在建造一座楼房时,先按一定的比例建造一个缩小的楼房模型,通过楼房模型的外观、形状和颜色的直接理解和认识,加强了对要建造的真正楼房的理解和认识。模型直观性很强,很容易发现那些不满意的设计,也很容易进行修改,经过用户和建设者反复讨论修改,最终可得到用户满意的模型,然后按照这个模型正式建造,这座楼房自然能满足用户要求。而软件开发中的原型是软件的一个早期可运行的版本,它反映了最终系统的重要特性。,2.,快速原型思想的产生,在,20,世纪,80,年代就出现了快速原型的思想,它是在研究需求分析阶段的方法和技术中产生的。由于种种原因,在需求分析阶段得到完全、一致、准确和合理的需求说明是很困难的。因此,在开发过程的早期,在获得一组基本需求说明后,就快速地使其,“,实现,”,,通过原型反馈,加深对系统的理解,并满足用户基本要求,使用户在试用过程中受到启发,对需求说明进行补充和精确化,还增进了开发者和用户对系统需求的理解。,使比较含糊的软件需求和功能明确化,还帮助开发者和用户发现和消除不协调的系统需求,逐步确定各种需求,从而获得合理、协调一致、无歧义的、完整的和现实可行的需求说明。,以后,又把快速原型思想用到软件开发的其他阶段,并向软件开发的全过程扩展,,即先用相对少的成本,较短的周期开发一个简单的、但可以运行的系统原型向用户演示或让用户试用,以便及早澄清并检验一些主要设计策略,在此基础上再开发实际的软件系统。,3.,快速原型的原理,快速原型是利用原型辅助软件开发的一种新思想。经过简单快速分析,快速实现一个原型,用户与开发者在试用原型过程中加强通讯与反馈,通过反复评价和改进原型,减少误解,弥补遗漏,适应变化,最终提高软件质量。,4.,原型运用方式,由于运用原型的目的和方式不同,在使用原型时也采取不同的策略,有,抛弃策略和附加策略。,抛弃策略是将原型用于开发过程的某一阶段,促使该阶段的开发结果更加完整、准确、一致和可靠,该阶段结束后,原型随之作废。,探索型和实验型快速原型就是采用此策略的,。,附加策略是将原型用于开发的全过程,原型由最基本的核心开始,逐步增加新的功能和新的需求,反复修改反复扩充,最后成为用户满意的最终系统。演化型快速原型就采用此策略。,采用何种形式、何种策略运用快速原型主要取决于软件项目的特点、人员素质、可供支持的原型开发工具和技术等,这要根据实际情况的特点来决定。,7.3.2,快速原型模型表示,快速原型模型的表示如图,7.3,所示。图,7.3(a),说明了原型本身的表示,图,7.3(b),说明了原型的使用过程,图,7.3(c),说明了快速原型模型的开发过程。,图7.3 快速原型模型,(,a),原型;(,b),原型的使用;(,c),开发过程,在图,7.3(c),中,实线箭头连接的表示探索型快速原型模型的开发过程,双线箭头连接的表示实验型快速原型模型的开发过程,虚线箭头连接的表示演化型快速原型模型的开发过程。,对于探索型,用原型过程来代替需求分析,把原型作为需求说明的补充形式,运用原型尽可能使需求说明完整、一致、准确和无二义性,但在整体上仍采用瀑布模型。,对于实验型,用原型过程来代替设计阶段,即在设计阶段引入原型,快速分析实现方案,快速构造原型,通过运行,考察设计方案的可行性与合理性,原型成为设计的总体框架或设计结果的一部分。,对于演化型,用原型过程来代替全部开发阶段。这是典型的演化提交模型的形式,它是在强有力的软件工具和环境支持下,通过原型过程的反复循环,直接得到软件系统。不强调开发的严格阶段性和高质量的阶段性文档,不追求理想的开发模式。,7.3.3,原型开发过程,1.,原型构造要求,原型不同于最终系统,,两者在功能范围上的区别是最终系统要实现软件需求的全部功能,而原型只实现所选择的部分功能,;,最终系统对每个软件需求都要求详细实现,而原型仅仅是为了试验和演示用的,部分功能需求可以忽略或者模拟实现。,因此,在构造原型时,必须注意功能性能的取舍,忽略一切暂时不关心的部分以加速原型的实现,同时又要充分体现原型的作用,满足评价原型的要求。,在构造原型之前,必须明确运用原型的目的,从而解决分析与构造内容的取舍,还要根据构造原型的目的确定考核、评价原型的内容。,2.,原型的特征分类,根据原型的目的和方式不同,构造原型的内容的取舍不同,体现出原型特征有如下类别:,(1),系统的界面形式,用原型来解决系统的人机交互界面的结构。,(2),系统的总体结构,用原型来确定系统的体系结构。,(3),系统的主要处理功能和性能,用原型来实现系统的主要功能和性能。,(4),数据库模式,用原型来确定系统的数据库结构。,3.,原型开发步骤,1),快速分析,在分析人员与用户紧密配合下,迅速确定系统的基本需求,根据原型所要体现的特征,(,如上述的特征类别,),,描述基本需求以满足开发原型的需要。其关键要注意分析与描述内容的选取,围绕运用原型的目标,集中力量确定局部的需求说明,从而尽快开始构造原型。,2),构造原型,在快速分析的基础上,根据基本需求说明尽快实现一个可运行的系统。这里要求具有强有力的软件工具支持,并忽略最终系统在某些细节上的要求,如安全性、坚固性和例外处理等,主要考虑原型系统能够充分反映所要评价的特性,而暂时删除一切次要内容。例如,如果构造原型的目的在于确定输入界面的形式,则可借助于输入界面自动生成工具,(,如,FormGenerator,),,,由界面形式的描述和数据域的定义立即生成简单的输入模块,而暂时忽略有关善后处理工作及参照检查、值域检查等内
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 管理文书 > 施工组织


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!