软件生命周期与模型.ppt
第二讲 软件过程选择与定义认识软件与软件特点软件生命周期与阶段软件过程模型软件过程模型的选择软件过程的定义专题:CMM认识软件软件是计算机系统中与硬件相互依存的另一部分,它是包括程序,数据及其相关文档的完整集合。软件的特点软件是一种逻辑实体,而不是具体的物理实体。因而它具有抽象性。软件不是制造出来的,而是设计、开发出来的。在软件的运行和使用期间,没有硬件那样的机械磨损,老化问题。软件的开发和运行常常受到计算机系统的限制,对计算机系统有着不同程度的依赖性。软件的开发至今尚未完全摆脱手工艺的开发方式。软件的研制工作需要投入大量的、复杂的、高强度的脑力劳动,它的成本是比较高的。软件的分类系统软件:能与计算机硬件紧密配合在一起,使计算机系统各个部件、相关的软件和数据协调、高效地工作的软件。支撑软件:是协助用户开发软件的工具性软件,如包括帮助程序人员开发软件产品的工具。应用软件:是在特定领域内开发,为特定目的服务的一类软件。按软件服务对象的范围划分:项目软件:也称定制软件,是受某个特定客户(或少数客户)的委托,由一个或多个软件开发机构在合同的约束下开发出来的软件。产品软件:是由软件开发机构开发出来直接提供给市场,或是为千百个用户服务的软件。软件的开发几类软件开发任务老师布置编程作业:请设计一个计算10000以内素数的程序。上级命令就来袭弹导导弹的运行轨迹进行研究和提供演算模型,并要求3个月提供研究成果。电信公司委托某软件公司开发其城域网运行支撑系统,包括监测、配置、告警与维护等功能。用友公司对其财务软件的开发。微软公司对WINDOWS操作系统的开发。软件工程学-软件生命周期软件生命周期由软件定义、软件开发、教件维护三个时期组成。每个时期又分为若干个阶段。软件定义,又称为系统分析。确定软件开发的总目标,确定软件开发工程的可行性,确定实现工程目标应该采用的策赂和必须完成的功能,估计完成该项工程需要的资源和成本划定出工程进度表。软件定义,划分为三个阶段,即问题定义、可行性研究和需求分析。软件开发,是实现前一个时期定义的软件。它包含四个阶段:总体设计、详细设计、编码与单元测试、综合测试。软件维护的任务,是使软件能够持久地满足用户的需求。软件生命周期的六个阶段1、问题的定义及规划此阶段是软件开发方与需求方共同讨论,主要确定软件的开发目标及其可行性。2、需求分析 在确定软件开发可行的情况下,对软件需要实现的各个功能进行详细分析。3、软件设计 此阶段主要根据需求分析的结果,对整个软件系统进行设计,如系统框架设计,数据库设计等等。软件设计一般分为总体设计和详细设计。好的软件设计将为软件程序编写打下良好的基础。4、程序编码此阶段是将软件设计的结果转换成计算机可运行的程序代码。在程序编码中必须要制定统一,符合标准的编写规范。以保证程序的可读性,易维护性,提高程序的运行效率。5、软件测试在软件设计完成后要经过严密的测试,以发现软件在整个设计过程中存在的问题并加以纠正。6、运行维护软件维护是软件生命周期中持续时间最长的阶段。在软件开发完成并投入使用后,由于多方面的原因,软件不能继续适应用户的要求。要延续软件的使用寿命,就必须对软件进行维护。软件工程方法学n传统方法学(面向过程)传统方法学(面向过程)阶段、过程、自顶向下、审阶段、过程、自顶向下、审n面向对象面向对象要点:对象、类、继承、消息要点:对象、类、继承、消息n面向服务面向服务软件即服务、软件即服务、SaaSSaaS 软件过程模型软件过程软件过程 定义了软件生命周期的历程与阶段。过程阶段过程阶段构成了软件生命周期的基础,并且确立了前后阶段之间的关系,其中规定了技术方法的采用、工程产品(模型、文档、数据、报告)的产生、里程碑的建立、质量的保证及变化的适当管理。软件过程模型软件过程模型(1 1)线性顺序模型)线性顺序模型(传统生命周期或瀑布模型)特点:线性模型仍然是最基本的和最效的一种可供选择的软件开发生命周期模型,要求软件开发严格按照需求-分析-设计-编码-测试的阶段进行,每一个阶段都可以定义明确的产出物和验证准则,每一个阶段完成后都可以组织相关的评审和验证,只有在评审通过后才能够进入到下一个阶段。(2)快速原型模型原型模型 快速定义与实现软件的核心功能,检验是否符合软件的一般性目标。特点:原型可以分为抛弃型的和不抛弃型的.如果原型仅仅是需求阶段方面和用户沟通画的DEMO,则这种原型一般都建议抛弃掉.而对于迭代开发来将,每次迭代的产出都是可以独立运行和包含基础功能的系统,是后续细化的基础,这类原型一般都不建议抛弃,后期的设计开发也要基于该原型逐渐的进行完善。(3 3)螺旋模型)螺旋模型遵从瀑布模型,.即需求-架构-设计-开发-测试的路线,但整个开发过程是迭代和风险驱动的,通过将瀑布模型的多个阶段转化到多个迭代过程中,以减少项目的风险。特点:螺旋螺旋模型实现了随着项目成本投入不断增加,风险逐渐减小。以帮我我们加强项目的管理和跟踪,在每次迭代结束后都需要对产出物进行评估和验证,当发现无法继续进行下去时可以及早的终止项目。(4)增量模型增量模型 融合了线性顺序模型的基本成份(重复地应用)和原型的迭代特征。特点:就对风险的消除上,增量和迭代模型都能够很好的控制前期的风险并解决.(5)迭代模型迭代模型 主要适用于面向对象的开发过程。特点:就对风险的消除上,增量和迭代模型都能够很好的控制前期的风险并解决.(5)SOASOA模型模型 以互联网的应用为基础以互联网的应用为基础特点:就对风险的消除上,增量和迭代模型都能够很好的控制前期的风险并解决.关于选择生命周期模型的最后的总结1.在前期需求明确的情况下尽量采用瀑布模型或改进型的瀑布模型2.在用户无信息系统使用经验,需求分析人员技能不足情况下一定要借助原型.3.在不确定性因素很多,很多东西前面无法计划情况下尽量采用增量迭代和螺旋模型4.在需求不稳定情况下尽量采用增量迭代模型5.在资金和成本无法一次到位情况下可以采用增量模型,软件产品分多个版本进行发布6.对于完全多个独立功能开发可以在需求阶段就分功能并行,但每个功能内都应该遵循瀑布模型7.对于全新系统的开发必须在总体设计完成后再开始增量或并行.软件过程的选择依据软件过程的选择依据(1)软件需求的确定性程度(2)类似软件的开发经验(3)软件工程的性质(项目类型/产品类型)(4)客户的时间要求。软件过程定义的要素软件过程定义的要素任务集合里程碑软件工程产品和交付物质量保证点保护性活动(软件质量保证、软件配置管理等)软件生命周期定义举例软件生命周期定义举例专题:软件过程成熟度模型专题:软件过程成熟度模型过程成熟度(过程成熟度(CMMCMM)由软件工程研究所(SEI)提出,定义了当一个组织达到不同的过程成熟度时应该具有的软件工程能力。CMM的五个等级初始级 软件过程的特征是无序的,有时甚至是混乱的。没有过程定义,成功完全取决于个人能力。可重复级 建立了基本的项目管理过程,能够追踪费用、进度和功能。有适当的过程规范,使得可以重现以前类似项目的成功。定义级 用于管理和工程活动的软件过程已经文档化、标准化,并与整个组织的软件过程相集成。管理级 软件过程和产品质量的详细度量数据被收集,通过这些度量数据,软件过程和产品能够被定量地理解和控制。优化级 通过定量的反馈,进行不断的过程改进。