瀑布模型


瀑布模型(Waterfall Model)

什么是瀑布模型?

  1970年温斯顿·罗伊斯(Winston Royce)提出了著名的“瀑布模型”,直到80年代早期,它一直是唯一被广泛采用的软件开发模型。

瀑布模型核心思想

  瀑布模型核心思想是按工序将问题化简,将功能的实现与设计分开,便于分工协作,即采

pic-info">瀑布模型

用结构化的分析与设计方法将逻辑实现与物理实现分开。将软件生命周期划分为制定计划、需求分析、软件设计、程序编写、软件测试和运行维护等六个基本活动,并且规定了它们自上而下、相互衔接的固定次序,如同瀑布流水,逐级下落。

瀑布模型的重要地位

  瀑布模型是最早出现的软件开发模型,在软件工程中占有重要的地位,它提供了软件开发的基本框架。其过程是从上一项活动接收该项活动的工作对象作为输入,利用这一输入实施该项活动应完成的内容给出该项活动的工作成果,并作为输出传给下一项活动。同时评审该项活动的实施,若确认,则继续下一项活动;否则返回前面,甚至更前面的活动。对于经常变化的项目而言,瀑布模型毫无价值。(采用瀑布模型的软件过程如图所示)瀑布模型的优缺点

1、瀑布模型有以下优点

  1)为项目提供了按阶段划分的检

pic-info">瀑布模型

查点。
  2)当前一阶段完成后,您只需要去关注后续阶段。
  3)可在迭代模型中应用瀑布模型。
  增量迭代应用于瀑布模型。迭代1解决最大的问题。每次迭代产生一个可运行的版本,同时增加更多的功能。每次迭代必须经过质量和集成测试

2、瀑布模型有以下缺点

  1)在项目各个阶段之间极少有反馈。
  2)只有在项目生命周期的后期才能看到结果。
  3)通过过多的强制完成日期和里程碑来跟踪各个项目阶段。
  4)瀑布模型的突出缺点是不适应用户需求的变化.瀑布模型的客户需求
  尽管瀑布模型招致了很多批评,但是它对很多类型的项目而言依然是有效的,如果正确使用,可以节省大量的时间和金钱。对于您的项目而言,是否使用这一模型主要取决于您是否能理解客户需求以及在项目的进程中这些需求的变化程度,对于经常变化的项目而言,瀑布模型毫无价值,对于这种情况,您可以考虑其他的架构来进行项目管理,比如名为螺旋模型(spiral model)的方法。
  在瀑布模型中,软件开发的各项活动严格按照线性方式进行,当前活动接受上一项活动的工作结果,实施完成所需的工作内容。当前活动的工作结果需要进行验证,如果验证通过,则该结果作为下一项活动的输入,继续进行下一项活动,否则返回修改。
  瀑布模型强调文档的作用,并要求每个阶段都要仔细验证。但是,这种模型的线性过程太理想化,已不再适合现代的软件开发模式,几乎被业界抛弃,其主要问题在于:
  (1) 各个阶段的划分完全固定,阶段之间产生大量的文档,极大地增加了工作量;
  (2) 由于开发模型是线性的,用户只有等到整个过程的末期才能见到开发成果,从而增加了开发的风险
  (3) 早期的错误可能要等到开发后期的测试阶段才能发现,进而带来严重的后果。
  按照瀑布模型的阶段划分,软件测试可以分为单元测试,集成测试,系统测试