简述瀑布模型、增量模型、螺旋模型(含原形方法)。并分析优缺点
- 从项目特点、风险特征、人力资源利用角度思考
瀑布模型
瀑布模型中的每一个开发活动具有下列特征:
本阶段活动的工作对象来自于上一项活动的输出,这些输出一 般是代表本阶段活动结束的里程碑式的文档
根据本阶段的活动规程执行相应的任务
本阶段活动产出相关的软件工件,作为下一阶段活动的输入。
对本阶段活动执行情况进行评审
优点:
- 降低软件开发的复杂程度,提高软件开发过程的透明性,提高软件开发过程的可管理性
- 推迟软件实现,强调在软件实现前必须进行分析和设计工作
- 以项目的阶段评审和文档控制为手段有效地对整个开发过程进行指导,保证了阶段之间的正确衔接,能够及时发现并纠正开 发过程中存在的缺陷,使产品达到预期的质量要求
缺点:
- 强调过程活动的线性顺序
- 缺乏灵活性,特别是无法解决软件需求不明确或不准确的问题
- 风险控制能力较弱
- 瀑布模型中的软件活动是文档驱动的,当阶段之间规定过多的文档时,会极大地增加系统的工作量
- 管理人员如果仅仅以文档的完成情况来评估项目完成进度,往往会产生错误的结论
增量模型
增量模型首先对系统最核心或最清晰的需求进行分析、设计、实现、测试并集成到系统中,再按优先级逐步实现后续需求。
优点:
- 增强客户对系统的信心
- 降低系统失败风险
- 提高系统可靠性
- 提高系统的稳定性和可维护性
缺点:
增量粒度难以选择
确定所有的基本业务服务比较困难
螺旋模型
螺旋模型主要针对大型软件项目的开发
优点:
- 引入了明确的风险管理机制
- 风险驱动的迭代过程,强调可选方案和约束条件从而支持软件的重用,有助于将软件质量作为特殊目标融入产品开发之中
缺点:
螺旋模型强调风险分析,但说服外部客户接受和相信分析结果并做出相关反应并不容易
风险分析需要耗费相当的成本
失误的风险分析可能带来更大的风险
简述统一过程三大特点,与面向对象的方法有什么关系?
三大特点:
- 迭代式的增量开发:受控的迭代式增量开发
- 用例(Use case-driven)驱动
- 以软件体系结构为中心
统一过程是一个面向对象且基于网络的程序开发方法论。
简述统一过程四个阶段的划分准则是什么?每个阶段关键的里程碑是什么?
- 初始阶段
- 目标:为系统建立业务案例 (Business Case) 并确定项目的边界。业务案例包括项目的验收规范、风险评估、所需资源估计、阶段计划等。确定项目边界需要识别所有与系统交互的外部实体,并在较高层次上定义外部实体与系统交互的特性,主要包括识别外部角色 (Actor)、识别所有用例并详细描述一些重要的用例。
- 里程碑:生命周期目标 (Lifecycle Objective) 里程碑,包括一些重要的文档,如:项目构想 (Vision)、原始用例模型、原始业务 风险评估、一个或者多个原型、原始业务案例等。需要对这些 文档进行评审,以确定正确理解用例需求、项目风险评估合理、阶段计划可行等。
- 精化阶段
- 目标:分析问题领域,建立健全的体系结构基础,编制项目计划,完成项目中高风险需求部分的开发。
- 里程碑:生命周期体系结构 (Lifecycle Architecture) 里程碑。包括风险分析文档、软件体系结构基线、项目计划、可执行的进 化原型、初始版本的用户手册等。通过评审确定软件体系结构 已经稳定、高风险的业务需求和技术机制已经解决、修订的项 目计划可行等。
- 构建阶段
- 目标:完成所有剩余的技术构件和稳定业务需求功能的开发, 并集成为产品,详细测试所有功能。构建阶段只是一个制造过 程,其重点放在管理资源及控制开发过程以优化成本、进度和 质量。
- 里程碑:初始运行能力 (Initial Operational Capability) 里程碑。包括可以运行的软件产品、用户手册等,它决定了产品是否可 以在测试环境中进行部署。此刻,要确定软件、环境、用户是 否可以开始系统的运行。
- 产品化阶段/移交阶段
- 目标:确保软件对最终用户是可用的。产品化阶段可以跨越几次迭代,包括为发布做准备的产品测试,基于用户反馈的少量 调整。
- 里程碑:产品发布 (Product Release) 里程碑。确定最终目标是否实现,是否应该开始产品下一个版本的另一个开发周期。在 一些情况下这个里程碑可能与下一个周期的初始阶段的相重合。
- 初始阶段
软件企业为什么能按固定节奏生产、固定周期发布软件产品?它给企业项目管理带来哪些好处?
UP统一过程将软件的生命周期划分为四个阶段,每一阶段包含一个明确的里程碑,这样,每一阶段的长度固定下来。并且开发被组织成一系列固定的短期小项目,称为迭代,每次迭代都产生经过测试、集成并可执行的局部系统。每次迭代都具有各自的需求分析、设计、实现和测试活动。因此,在每次迭代完成后,都有一定的产品可供发布。
按固定节奏生产、固定周期发布产品给企业项目管理以更明确的目标和更好的软件开发节奏,提升效率,节省时间,也能更方便的安排团队的工作。