系统分析作业三

1. 简述瀑布模型、增量模型、螺旋模型(含原型方法)的优缺点

从项目特点、风险特征、人力资源利用角度思考

瀑布模型

  • 优点:
    • 为项目提供了按阶段划分的检查点,当一个阶段完成后,只需关注后续的阶段
    • 有利于大型软件开发过程中人员的组织、管理,有利于软件开发方法和工具的研究,从而提高了大型软件项目开发的质量和效率
    • 它提供了一个模板,这个模板使得分析、设计、编码、测试和支持的方法可以在该模板下有一个共同的指导。
  • 缺点
    • 各个阶段的划分完全固定,阶段之间产生大量的文档,极大地增加了工作量。
    • 由于开发模型是线性的,用户只有等到整个过程的末期才能见到开发成果,从而增加了开发风险。
    • 很难清楚地给出所有的需求。不适应用户需求的变化

增量模型

  • 优点
    • 人员分配灵活,刚开始不用投入大量人力资源
    • 可先发布部分功能给客户,对客户起到镇静剂的作用
    • 当配备的人员不能在设定的期限内完成产品时,它提供了一种先推出核心产品的途径,能够有计划地管理技术风险。
  • 缺点
    • 并行开发构件有可能遇到不能集成的风险,软件必须具备开放式的体系结构
    • 变化的能力大大优于瀑布模型和快速原型模型,但也很容易退化为边做边改模型,从而使软件过程的控制失去整体性
    • 在开发过程中,需求的变化是不可避免的。增量模型的灵活性可以使其适应这种变化的能力大大优于瀑布模型和快速原型模型,但也很容易退化为边做边改模型,从而是软件过程的控制失去整体性。
    • 如果增量包之间存在相交的情况且未很好处理,则必须做全盘系统分析,这种模型将功能细化后分别开发的方法较适应于需求经常改变的软件开发过程。

螺旋模型(含原型方法)

  • 优点
    • 设计上的灵活性,可以在项目的各个阶段进行变更
    • 客户始终参与每个阶段的开发,保证了项目不偏离正确方向以及项目的可控性
    • 以小的分段来构建大型系统,使成本计算变得简单容易
    • 在每个迭代阶段植入软件测试,使每个阶段的质量得到保证
  • 缺点
    • 需要具有相当丰富的风险评估经验和专门知识,在风险较大的项目开发中,如果未能够及时标识风险,势必造成重大损失
    • 会增加开发成本,延迟提交时间。
    • 过分依赖风险分析经验与技术,一旦在风险分析过程中出现偏差将造成重大损失。
    • 过于灵活的开发过程不利于已经签署合同的客户与开发者之间的协调。
    • 由于只适用大型软件,过大的风险管理支出会影响客户的最终收益。

2. 简述统一过程三大特点,与面向对象的方法有什么关系?

  • 三大特点:

    • 用例驱动
      用例驱动既做到了以客户为中心,以客户的角度看系统,为客户创建真正可用的系统的构造方式,又解决了传统面向对象方法面临的无法有效的从需求中提取对象的困难,从而填平了需求分析方法和对象设计方法之间的鸿沟。
    • 以架构为中心
      以架构为中心,坚持综合考虑软件系统的各个方面,并优先解决各个方面的主要问题,同时创建常见问题的通用解决方案,从而为解决软件项目的主要风险、准确估算项目进度、提高软件复用、保证软件的整体风格打下了坚实基础。
    • 受控的迭代式增量开发
      迭代和增量式开发,以风险为驱动,分阶段针对不同的风险制定对策,以保证软件项目的成功完成。
  • 与面向对象的方法的关系
    用例驱动和受控的迭代时增量开发体现了用户驱动的开发。早期的迭代目标要能够识别与降低最高风险,并且能构造客户最关心的可视化特性。
    以架构为中心体现了风险驱动的开发,早期迭代要致力于核心架构的构造、测试和稳定。因为没有稳固的架构就会带来高风险。

3. 简述统一过程四个阶段的划分准则是什么?每个阶段关键的里程碑是什么?

  • 初始阶段 (inception):该阶段的主要目的是建立项目的范围和版本,确定项目目标的可行性和稳定性,结交结果包括需求和用例。初始阶段结束时是第一个重要的里程碑:生命周期目标(Lifecycle Objective) 里程碑。生命周期目标里程碑评价项目基本的生存能力。

  • 细化阶段 (elaboration):该阶段的目的是对问题域进行分析,建立系统需求和架构,确定实现的可行性和稳定性,提交结果包括系统架构,问题领域、修改后的需求及项目开发计划等相关文档。细化阶段结束时第二个重要的里程碑:生命周期结构 (Lifecycle Architecture) 里程碑。生命周期结构里程碑为系统的结构建立了管理基准并使项目小组能够在构建阶段中进行衡量。

  • 构造阶段:完成所有剩余的技术构件和稳定业务需求功能的开发,并集成为产品,详细测试所有功能。构建阶段只是一个制造过程,其重点放在管理资源及控制开发过程以优化成本、进度和质量。构建阶段结束时是第三个重要的里程碑:初始功能 (Initial Operational) 里程碑。初始功能里程碑决定了产品是否可以在测试环境中进行部署。

  • 交付阶段:确保软件对最终用户是可用的。产品化阶段可以跨越几次迭代,包括为发布做准备的产品测试,基于用户反馈的少量调整。在交付阶段的终点是第四个里程碑:产品发布 (Product Release) 里程碑。

4. 软件企业为什么能按固定节奏生产、固定周期发布软件产品?它给企业项目管理带来哪些好处?

因为UP将开发分割四个阶段,每个阶段里程碑明确,易于评估是否满足。每个迭代过程都有固定的时长和产品生成。进而为企业按固定节奏生产、固定周期发布软件产品提供了依据。UP是一个风险驱动的生命周期模型,为了有效地控制风险,UP以渐进的方式进行演进,首先解决高风险的问题,这主要是通过迭代来实现。在软件生命周期中,每个阶段可以划分为多个迭代,每个迭代确定一个内部里程碑。因此,UP也为固定周期发布软件产品提供了依据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值