构建高效的软件开发流程

软件开发流程
迭代化软件开发技术 构建高效的软件开发流程
构建高效的软件开发流程
构建高效的软件开发流程
构建高效的软件开发流程
构建高效的软件开发流程

1. 传统开发流程的问题 
传统的 软件开发流程是一个文档驱动的流程,它将整个软件开发过程划分为顺序相接的几个阶段,每个阶段都必需完成全部规定的任务(文档)后才能够进入下一个阶段。 如必须完成全部的系统需求规格说明书之后才能够进入概要设计阶段,编码必需在系统设计完成之后才能够进行。这就意味着只有当所有的系统模块全部开发完成之 后,我们才进行系统集成,对于一个由上百个模块组的复杂系统来说,这是一个非常艰巨而漫长的工作。

构建高效的软件开发流程

随着我们所开发的软件项目越来越复杂,传统的瀑布型开发流程不断地暴露出以下问题:

  • 需求或设计中的错误往往只有到了项目后期才能够被发现例如:系统交付客户之后才发现原先对于需求的理解是错误的,系统设计中的问题要到测试阶段才能被发现。
  • 对于项目风险的控制能力较弱项目风险在项目开发较晚的时候才能够真正降低,往往是经过系统测试之后,才能确定该设计是否能够真正满足系统需求。
  • 软件项目常常延期完成或开发费用超出预算项目开发进度往往会被意外发生的问题所打乱,需要进行返工或其他一些额外的开发周期,造成项目延期或费用超支。
  • 项目管理人员专注于文档的完成和审核来估计项目的进展情况所以项目经理对于项目状态的估计往往是不准确的,当他回答系统已完成了80%的开发任务时,剩下20%的开发任务实际上消耗的是整个项目80%的开发资源。

在传统的瀑布模型中,需求和设计中的问题是无法在项目开发的前期被检测出来的,只有当第一次系统集成时,这些设计缺陷才会在测试中暴露出来,从而导致一系列的返工:重新设计、编码、测试,进而导致项目的延期和开发成本的上升。

构建高效的软件开发流程

2. 采用迭代化开发控制项目风险 
为 了解决传统软件开发流程中的问题,我们建议采用迭代化的开发方法来取代瀑布模型。在瀑布模型中,我们要完成的是整个软件系统开发这个大目标。在迭代化的方 法中,我们将整个项目的开发目标划分成为一些更易于完成和达到的阶段性小目标,这些小目标都有一个定义明确的阶段性评估标准。迭代就是为了完成一定的阶段 性目标而所从事的一系列开发活动,在每个迭代开始前都要根据项目当前的状态和所要达到的阶段性目标制定迭代计划,整个迭代过程包含了需求、设计、实施(编 码)、部署、测试等各种类型的开发活动,迭代完成之后需要对迭代完成的结果进行评估,并以此为依据来制定下一次迭代的目标。

构建高效的软件开发流程

与传统的瀑布式开发模型相比较,迭代化开发具有以下特点:

  • 允许变更需求
    需求总是会变化,这是事实。给项目带来麻烦的常常主要是需求变化和需求”蠕变”,它们会导致延期交付、工期延误、客户不满 意、开发人员受挫。通过向用户演示迭代所产生的部分系统功能,我们可以尽早地收集用户对于系统的反馈,及时改正对于用户需求的理解偏差,从而保证开发出来 的系统真正地解决客户的问题。
  • 逐步集成元素
    在传统的项目开发中,由于要求一下子集成系统中所有的模块,集成阶段往往要占到整个项目很大比例的工作量(最 高可达40%),这一阶段的工作经常是不确定并且非常棘手。在迭代式方法中,集成可以说是连续不断的,每一次迭代都会增量式集成一些新的系统功能,要集成 的元素都比过去少得多,所以工作量和难度都是比较低的。
  • 尽早降低风险
    迭代化开发的主要指导原则就是以架构为中心,在早期的迭代中所要解决的主要问题就是尽快确定系统架构,通过几 次迭代来尽快地设计出能够满足核心需求的系统架构,这样可以迅速降低整个项目的风险。等到系统架构稳定之后,项目的风险就比较低了,这个时候再去实现系统 中尚未完成的功能,进而完成整个项目。
  • 有助于提高团队的士气
    开发人员通过每次迭代都可以在短期内看到自己的工作成果,从而有助于他们增强信心,更好地完成开发任务。而在非迭代式开发中,开发人员只有在项目接近尾声时才能看到开发的结果,在此之前的相当长时间,大家还是在不确定性中摸索前近。
  • 生成更高质量的产品
    每次迭代都会产生一个可运行的系统,通过对这个可运行系统进行测试,我们在早期的迭代中就可以及时发现缺陷并改正,性能上的瓶颈也可以尽早发现并处理。因为在每次迭代中总是不断地纠正错误,我们可以得到更高质量的产品。
  • 保证项目开发进度
    每次迭代结束时都会进行评估,来判断该次迭代有没有达到预定的目标。项目经理可以很清楚地知道有哪些需求已经实现了,并且比较准确地估计项目的状态,对项目的开发进度进行必要的调整,保证项目按时完成。
  • 容许产品进行战术改变
    迭代化的开发具有更大的灵活性,在迭代过程中可以随时根据业务情况或市场环境来对产品的开发进行调整。例如为了同现有的同类产品竞争,可以决定采用抢先竞争对手一步的方法,提前发布一个功能简化的产品。
  • 迭代流程自身可在进行过程中得到改进和精炼
    一次迭代结束时的评估不仅要从产品和进度的角度来考察项目的情况,而且还要分析组织和流程本身有什么待改进之处,以便在下次迭代中更好地完成任务。

构建高效的软件开发流程

迭代化方法解决的主要是对于风险的控制问题,从下图可以看出,传统的开发流程中系统的风险要到项目开发的后期(主要是测试阶段)才能够被真正降低。 而迭代化开发中的风险,可以在项目开发的早期通过几次迭代来尽快地解决掉。在早期的迭代中一旦遇到问题,如某一个迭代没有完成预定的目标,我们还可以及时 调整开发进度以保证项目按时完成。一般到了项目开发的后期(风险受控阶段),由于大部分高风险的因素(如需求、架构、性能等)都已经解决,这时候只需要投 入更多的资源去实现剩余的需求即可。这个阶段的项目开发具有很强的可控性,从而保证我们按时交付一个高质量的软件系统。

构建高效的软件开发流程

迭代化开发不是一种高深的软件工程理论,它提供了一种控制项目风险的非常有效的机制。在日常的工作我们也经常地应用到这一基本思想,如对于一个非常 大型的工程项目,我们经常会把它分为几期来分步实施,从而把复杂的问题分解为相对容易解决的小问题,并且能够在较短周期内看到部分系统实现的效果,通过尽 早暴露问题来帮助我们及早调整我们的开发资源,加强项目进度的可控程度,保证项目的按时完成。

3. 管理迭代化的软件项目 
当我 们在实际工作中实践迭代化思想时,Rational统一开发流程RUP(Rational Unified Process)可以给予我们实践的指导。RUP是一个通用的软件流程框架,它是一个以架构为中心、用例驱动的迭代化软件开发流程。RUP是从几千个软件 项目的实践经验中总结出来的,对于实际的项目具有很强的指导意义,是软件开发行业事实上的行业标准。

3.1 软件开发的四个阶段 
在RUP中,我们把软件开发生命周期划分为四个阶段,每个阶段的结束标志就是一个主要的里程碑(如下图所示)。

构建高效的软件开发流程

这四个阶段主要是为了达到以下阶段性的目标里程碑:

  • 先启(Inception):确定项目开发的目标和范围
  • 精化(Elaboration):确定系统架构和明确需求
  • 构建(Construction):实现剩余的系统功能
  • 产品化(Transition):完成软件的产品化工作,将系统移交给客户

每个目标里程碑都是一个商业上的决策点,如先启阶段结束之后,我们就要决定这个项目是否可行、是否要继续做这个项目。每一个阶段都是由里程碑来决定的,判断一个阶段是否结束的标志就是看项目当前的状态是否满足里碑中所规定的条件。

从这种阶段划分模式中可以看出,项目的主要风险集中在前两个阶段。在精化阶段中经过几次迭代后,我们要为系统建立一个稳定的架构,在此之后再实现更 多的系统需求时,不再需要对该架构进行修改。同时,在精化阶段中,我们通过迭代来不断地收集用户的需求反馈,便得系统的需求逐步地明确和完整。

3.2 关于开发资源的分配 
基于 RUP风险驱动的迭代化开发模式,我们只需要在项目的先启阶段投入少量的资源,对项目的开发前景和商业可行性进行一些探索性的研究。在精化阶段再投入多一 些的研发力量来实现一些与架构相关的核心需求,逐步地把系统架构搭建起来。等到这两个阶段结束之后,项目的一些主要风险和问题也得到了解决,这时候再投入 整个团队进行全面的系统开发。等到产品化阶段,主要的开发任务已经全部完成,项目不再需要维持一个大规模的开发团队,开发资源也可以随之而减少。在项目开 发周期中,开发资源的分配可以如下图所示。

构建高效的软件开发流程

这样安排可以最充分有效地利用公司的开发资源,缓解软件公司对于人力资源不断增长的需求,从而降低成本。另外一方面,由于前两个阶段(先启和精化) 的风险较高,我们只是投入部分的资源,一旦发生返工或是项目目标的改变,我们也可以将资源浪费降到最低点。在传统的软件开发流程中,对于开发资源的分配基 本上是贯穿整个项目周期而不变的,资源往往没有得到充分有效地利用。

基于这种资源分配模式,一个典型的项目在项目进度和所完成的工作量之间的关系可能如下表中的数据所示。

先启 精化 构建 产品化
工作量 ~5% 20% 65% 10%
进度 10% 30% 50% 10%

3.3 迭代策略 
关于迭代计划的安排,通常有以下四种典型的策略模式:

  • 增量式(Incremental)
    这种模式的特点是项目架构的风险较小(往往是开发一些重复性的项目),所以精化阶段只需要一个迭代。但项目的开发工作量较大,构建阶段需要有多次迭代来实现,每次迭代都在上一次迭代的基础上增加实现一部分的系统功能,通过迭代的进行而逐步实现整个系统的功能。
  • 演进式(Evolutionary)
    当项目架构的风险较大时(从未开发过类似项目),需要在精化阶段通过多次迭代来建立系统的架构,架构是通过多次迭代的探索,逐步演化而来的。当架构建立时,往往系统的功能也已经基本实现,所以构建阶段只需要一次迭代。
  • 增量提交(Incremental Delivery)
    这种模式的特点产品化阶段的迭代较多,比较常见的例子是项目的难度并不 大,但业务需求在不断地发生变化,所以需要通过迭代来不断地部署完成的系统;但同时又要不断地收集用户的反馈来完善系统需求,并通过后续的迭代来补充实现 这些需求。应用这种策略时要求系统架构非常稳定,能够适应满足后续需求变化的要求。
  • 单次迭代(Grand Design)
    传统的瀑布模型可以看作是迭代化开发的一个特例,整个开发流程只有一次迭代。但这种模式有一个固有的弱点,由于它对风险的控制能力较差,往往会在产品化阶段产生一些额外的迭代,造成项目的延误。

这几种迭代策略只是一些典型模式的代表,实际应用中应根据实际情况灵活应用,最常见的迭代计划往往是这几种模式的组合。

3.4 制定项目开发计划 
在迭代 化的开发模式中,项目开发计划也是随着项目的进展而不断细化、调整并完善的。传统的项目开发计划是在项目早期制定的,项目经理总是试图在项目的一开始就制 定一个非常详细完善的开发计划。与之相反,迭代开发模式认为在项目早期只需要制定一个比较粗略的开发计划,因为随着项目的进展,项目的状态在不断地发生变 化,项目经理需要随时根据迭代的结果来对项目计划进行调整,并制定下一次迭代的详细计划。

在RUP中,我们把项目开发计划分为以下三部分:

  • 项目计划
    确定整个项目的开发目标和进度安排,包括每一个阶段的起止时间段。
  • 阶段计划
    当前阶段中包含有几个迭代,每一次迭代要达到的目标以及进度安排。
  • 迭代计划
    针对当前迭代的详细开发计划,包括开发活动以及相关资源的分配。

项目开发计划也是完全体现迭代化的思想,每次迭代中项目经理都会根据项目情况来不断地调整和细化项目开发计划。迭代计划是在对上一次迭代结果进行评 估的基础上制定的,如果上一次迭代达到了预定的目标,那么当前迭代只需要解决剩下的问题;如果上一次迭代中留有一些问题还没有解决,则当前迭代还需要继续 去解决这些问题。所以必须注意,迭代是不能重叠的,即你还没有完成当前迭代时,你决不能进入下一迭代,因为下一次迭代的计划是根据当前迭代的结果而制定 的。

 

Rational开发过程 构建高效的软件开发流程
构建高效的软件开发流程
构建高效的软件开发流程
构建高效的软件开发流程
构建高效的软件开发流程

 

1. 引言 
本文对 Rational 软件开发过程(Rational Software Development Process)的原理和结构给出了高度的描述,它是:

  • 迭代的、增量的开发过程
  • 面向对象的开发过程
  • 管理和控制的开发过程

它具有足够的普遍性,可以在规模与应用领域方面,为各个软件产品和项目量身订做。

2.总体软件生命周期

2.1 两种视角 
Rational 过程可以从两种不同而又密不可分的视角来观察:

  • 从管理的视角来看,涉及财务、战略、商业和人文方面
  • 从技术的视角来看,涉及质量、工程和设计方法方面

2.2 周期和阶段

构建高效的软件开发流程

从管理的角度,即从业务和经济的角度来看,对应项目的进展,软件的生命周期包含四个主要阶段:

  • 起始阶段(Inception)– 有一个好的想法:详细构想出最终产品的设想和它的业务案例,确定项目的范围 。
  • 细化阶段(Elaboration)–计划必要的活动和所需资源,详细确定功能并设计构架 。
  • 构建阶段(Construction)– 构建产品, 发展最初的设想、构架和计划,直到一个可以交付给用户的产品(完成后的设想)完成。
  • 移交阶段(Transition)– 将产品移交用户使用,包括:制造、交付、培训、支持、维护,直到用户满意。

完成这4个阶段称为一个开发周期, 它产生的软件称作第一代(generation)。 除非产品的生命结束, 一个现有产品可以通过重复下一个相同的起始、细化、构建和移交四阶段,各个阶段的侧重点与第一次不同,从而演进为下一代产品。 这个时期我们称之为演进(evolution)。最后伴随着产品经过几个周期的演进,新一代产品也不断被制造出来。

例如,演进周期的启动可能由以下这几项触发:用户建议增强功能、用户环境的改变、重要技术的变更,以及应对竞争的需要。

构建高效的软件开发流程

实际中,周期之间会有轻微重叠:起始阶段和细化阶段可能会在上一个周期的移交阶段未结束时就开始了。

2.3. 迭代 
从技术的角度来 看,软件开发可以视为一连串的迭代过程,通过这些迭代被开发的软件得以增量演进。 每次迭代都以一个可执行的产品的发布而结束, 该产品可能是完整版本的一个子集,但从工程的或用户的角度来看是有用的。 每次发布都伴随一些支持性工件:版本描述、用户文档和计划等。

构建高效的软件开发流程

一次迭代包括以下活动: 计划、分析、设计、实施和测试。 根据迭代在开发周期中所处位置的不同,这些活动分别占不同的比例。

管理角度和技术角度之间是协调的, 而且各个阶段的结束还和各次迭代的结束保持同步。

换句话说,每个阶段可以分为一次或多次迭代过程。

(注意:本图中每阶段的迭代数目仅为示意) 

构建高效的软件开发流程

但是,这两个角度(管理角度和技术角度),不仅仅只是保持同步,它们还具有一些完全相同的里程碑,它们共同贡献出一些随时间演进的产品和工件。 一些工件更多地处于技术方面控制之下,另一些工件更多地处于管理方面的控制之下。见第五节。

这些工件的可用性、工件是否满足所建立的评估标准,是构成里程碑的主要具体元素,比日历牌上的日期提供了多得多的内容。

像周期一样,迭代之间也会有轻微重叠。即第N次迭代的计划和构架在第N-1次迭代还未结束时就开始了。有时候,迭代也会平行进行:一个工作于系统某一部分的小组,可能在某个迭代内没有可交付的工件。

2.4.区别 
对于不同的项目而言,每个阶段的侧重点,入口和出口准则,一个开发周期的各个工件,以及各次迭代的数目和长度都会不同。这主要取决于作为过程判别式的的四个主要项目特征。按照影响程度降序排列,它们是:

  • 业务环境
    • 契约性工作,开发者基于给定的客户规格说明只为该客户开发软件。
    • 推测性开发或商业开发,开发者开发软件以推向市场。
    • 内部项目, 开发者和客户在同一个机构中。
  • 软件开发工作量的规模:
    按照一些度量标准来确定,比如 Delivered Source Instructions,或功能点、人-月数,或者只按照成本。
  • 新颖程度:
    对于软件开发组织,这个软件新颖程度如何有多新,尤其是该软件是否为第二次或更后面的周期。这项区别包括了组织和过程的成熟度、资产、技术水平,当前的技状况,以及诸如组建并培训团队、获取工具及其他资源这样的问题。
  • 应用类型,目标领域:
    MIS,命令和控制系统, 嵌入式实时系统, 软件开发环境工具等等, 尤其时具体的应用领域会给开发提出特殊的约束条件:安全性、性能、国际化、内存限制等。
    本文首先描述适用所有类型软件开发的通用过程,然后描述了一些有区别价值的特定过程实例,并列举了几个例子。

2.5工作量和日程安排 
各阶段在工作量和时间安排上是不同的。尽管由于不同项目类型之间相差会很大,一个典型的中等规模项目的最初开发周期可以预计为下面的比率:

起始阶段 细化阶段 构建阶段 移交阶段
工作量 5% 20% 65% 10%
日程安排 10% 30% 50% 10%

可以用下图表示:

构建高效的软件开发流程

但是对于一个演进周期来说,起始阶段和细化阶段可能大大缩减。使用特定工具和技术(如应用程序构建器),构建阶段可以远远小于起始阶段和细化阶段的总和。

3. Rational 过程的各个阶段

3.1. 起始阶段 
这个阶段产生一个预测产品的最初设想,并将其转换为一个实际的项目。本阶段的目的是建立一个新产品或一次大的更新的业务案例,并且指定项目的范围。

对于一个新产品的开发,本阶段的主要结果是得到一个”做还是不做”的决定以进入下一阶段,并投入一定的时间和资金来详细分析构建什么、能否构建,以及如何构建。

对于一个现有产品的演进,这会是一个简短的阶段, 主要看用户或客户的要求、问题报告,或是新的技术动态。

对于一个契约性的开发,是否进行项目的决定取决于在特定领域的经验、以及组织在此领域的竞争力和市场情况。这里起始阶段可以归结为一个参加投标的决定,或投标活动本身。该决定可能是基于一个现有的研究原型,其结构对最终软件可能合适,也可能不合适。

入口准则:

对于一项需要的描述,可以采用以下形式:

  • 一份最初的设想
  • 一个遗留系统
  • 一份建议请求(An RFP –request for proposal)
  • 先前一代的产品和一个增强要求清单
  • 一些资产(软件, 专门技能, 财务资产)
  • 一个概念原型或实物模型

出口准则:

  • 一个初始的业务案例至少要包含以下内容:
    • 对产品设想的明确表达即核心需求,表述为功能、范围、性能、容量和技术等。
    • 成功标准 (如收入的数目)
    • 最初的风险评估
    • 完成细化阶段所需的资源估算

通常在初试阶段结束时,我们将得到:

  • 一个最初的域分析模型(完成大约10%-20%), 确定最关键的用例, 并且足以进行进构架工作。
  • 一个最初的构架原型,在这个阶段可以是一个一次性原型

3.2. 细化阶段 
本阶段的主要目的是更彻底地分析问题域,定义构架并使之稳定,确定项目的最大风险。这样在本阶段结束时,我们可以得到一个关于下2个阶段如何工作的综合计划:

  • 一个基于分析模型的基线产品设想(即最初的需求集合)。
  • 至少对第一次构建迭代的评价准则。
  • 一个基线软件构架。
  • 开发和部署产品的必需资源,尤其是人员和工具。
  • 一份日程安排。
  • 足以对构建阶段的成本、日程安排和质量做出”精确”的评估的一份风险决议。

在这个阶段,建立了一个可执行的构架原型;它至少实现了初始阶段识别出的最关键的用例 ,解决了项目的最大技术风险;根据范围、规模、风险和项目新颖程度的不同构架原型需要一次或多次迭代。这是一个生成高质量代码(这些代码成为架构基线)的 演进原型,但是也不排除开发出一个或几个试探性的、一次性原型,以降低开发的风险:对需求、可行性、人机界面研究、向投资者演示等的精化。在本阶段的结束 时,仍然会产生一个”做还是不做”的决定, 以确定是否要真正投资构建这个产品(或参与合同项目的竞标)。

此时产生的计划一定要足够详细,风险也必须充分降低,可以对开发工作的完成进行精确的成本和日程估算。

入口准则:

  • 前一阶段出口准则所描述的产品和工件
  • 被项目管理者和投资者认可的计划,和细化阶段所需的资源

出口准则:

  • 一份详细的软件开发计划,包含:
    • 更新后的风险评估
    • 一份管理计划
    • 一份人员配置计划
    • 一份显示迭代内容和次数的阶段计划
    • 一份迭代计划,详细计划下次迭代
    • 开发环境和所需的其他工具
    • 一份测试计划
  • 一个基线设想,以对最终产品的一个评估准则的集合的形式
  • 用于评估构建阶段最初的迭代结果的客观、可测量的演进标准
  • 一个域分析模型(80%完成),相应的构架可以称之为是”完整的”
  • 一个软件构架描述(说明约束和限制)
  • 一个可执行的构架基线

3.3. 构建阶段 
本阶段可以划 分为数次迭代,不断充实构架基线,向最终产品逐步演进或增量演进。在每次迭代过程中,上个阶段(细化阶段)的工件得到扩充和修正, 但它们最终将随着系统向正确和完整的方向的演进而稳定下来。在这个阶段,除了软件本身,还生成一些新的工件:文档(既有内部使用的文档,也有面向最终用户 的文档)、测试床及测试套件、部署附件,以及用于支持下一阶段的部署辅助(例如销售辅助)。

对每次迭代,都具有:

入口准则:

  • 上次迭代的产品和工件。 迭代计划必须阐明迭代的特定目标:
    • 将要开发的新增功能,覆盖了哪些用例或场景
    • 本次迭代过程中减少的风险
    • 本次迭代过程中修改的缺陷

出口准则:

更新后的产品和工件,另外还有:

  • 一个版本描述文档,记录了迭代的结果
  • 测试用例和根据产品得出的测试结果
  • 一个详细描述下一次迭代的计划
  • 对下一次迭代的客观度量标准

到构建阶段的后期,必须完成以下工件,及本阶段最后一次迭代额外的出口准则:

  • 一个部署计划,指定必需的事项:
    • 打包
    • 定价
    • 演示
    • 支持
    • 培训
    • 移交策略 (例如一个现有系统的更新计划)
    • 产品 (软盘和手册)
  • 用户文档

3.4. 移交阶段 
移交阶段是将产品交付给最终用户的阶段。 它涉及销售、打包、安装、配置、支持用户社区和做出修正等.

从技术角度来看,伴随本阶段迭代的是一次或多次发布:`beta’ 版发布、正式版发布、修补bug , 或增强版发布。

当用户对产品满意时,本阶段即告结束。 例如,契约性开发时正式验收, 或者产品有关的所有活动都已结束。 此时,某些积累的资产可以加以整理,以为下一个周期或其他项目重用。

入口准则:

  • 上一次迭代的产品和工件, 尤其是足够成熟可以交付给用户的软件产品

出口准则:

  • 前一阶段某些文档的更新,以及必要时根据原始及修订后的成功标准,进行”事后”项目性能分析,从而替换原有计划。
  • 一个简短的清单,列出本次开发周期给组织带来的新的资产

3.5. 演进周期 
对于重要的演进,我们应用整个过程递归,仍从起始阶段开始一个新的周期。因为我们已经有了一个产品,所以比起一个初次开发的产品,起始阶段可能大大缩短。细化阶段也可能缩小范围,而在计划方面的关注程度要大于分析或构架的演进方面。需要指出:周期之间可以略有重叠。

较小的演进可以通过延长移交阶段或增加一两次迭代来完成。

移交阶段可以以一个终结过程而结束,即产品不再演进了,但是为了终结它,需要采取一些特定的动作。

4. Rational过程中的活动 
Rational 过程中各个阶段的名称(如起始、细化、构建、移交)与描述高级活动的术语(如分析、设计、测试等)相差甚远。 因此我们容易理解某种活动的进行并不局限于某个特定阶段,也与其他作者、标准及特定领域的所使用的术语无关。这些活动确实发生,但它们在每个阶段和每次迭 代中的程度有所不同。下图表明了活动重点如何随时间的推进而发生演进。

构建高效的软件开发流程

图中活动重点的变化也说明尽管每次迭代在形式上都是”相似”的,但它们的性质和内容却是随时间而改变的。

这还表明,一项活动的结束并不总意味着另一项活动的开始,即并不是分析完成了才开始设计,而是这些活动相关的各种”工件”在随着开发者对问题或需求的理解的加深也不断得到更新。

最后,在一个迭代过程中,计划、测试和集成这些活动不是集中堆积在开发活动的开始和结束阶段,而是增量地分布在整个开发周期的各个阶段、每次迭代之中。 它们并不表现为开发过程的某个独立的阶段或步骤。

尽管具体的项目有具体的区别,但对于一个中等规模、初次开发的典型项目来说,其开发周期中各种活动的比例如下:

计划与管理 15%
分析/需求 10%
设计/集成 15%
实施/功能测试 30%
度量/评估/验收测试 15%
工具/环境/变更管理 10%
维护(开发过程中的修补) 5%

5. 生命周期工件 
开发过程不是文档驱动的:它的工件中必须一直包括软件产品自身。文档应该十分精简,数目不能太多,应只保留那些确实从管理或技术的角度有真正价值的文档。 Rational 建议保留以下典型的文档集。

5.1管理工件 
管理工件不是产品,而是用来驱动或监控项目进展、估计项目风险、调整项目资源,以及使客户或投资者对项目保持一定的”可见性” 的。

  • 一份机构策略文档,是机构开发过程的明文规定。 它包含一个此类项目的实例。
  • 一份远景文档, 描述系统级需求,质量要求和优先级。
  • 一份业务案例文档, 描述财务环境、合同,以及项目的投资回报等等。
  • 一份开发计划文档, 包括总体的迭代计划和当前及近期迭代的详细规划。
  • 一份评估标准文档,包括需求、验收标准及其他特定的技术目标,它们由各个阶段演进的主要”里程碑”组成。包含迭代的目标和验收水平。
  • 每次发布的版本描述文档。
  • 部署文档, 包含对交付、培训、安装、销售、制造和交割相关的有用信息。
  • 状态评估文档: 项目状态的阶段性”快照”, 具有进展、人力、开销、结果、关键风险、活动等的度量标准。

5.2技术工件 
它们或者是交付的产品,可执行的软件及手册,或者是一些用于制造产品的蓝图,这些产品包括软件模型、源代码和其他有助于理解和演进产品的工程信息。

  • 用户手册, 在生命周期早期开发。
  • 软件文档, 最好以源代码自建文档和模型的形式,其中模型是用合适的CASE工具捕获并维护的这些模型包括用例、类图和过程图等。
  • 一个软件构架文档, 描述软件的整体构架,及它的主要组成元素的分解说明: 类的分组、类、过程、子系统、关键接口的定义和关键设计决策的依据。

本文第3部分中列举的入口准则和出口准则可以映射到这11类文档之中。

上面介绍的这套文档可以依照具体项目的类型进行扩充和删减,一些文档可以合并。 文档不必一定是纸张形式—也可以是电子表格、文本文件、数据库、源代码的注释、超文本文档等等—但相应的信息资源必须被清楚地识别,易于访问,也要保存一些历史记录。

5.3需求 
Rational 软件开发过程也不是需求驱动的。 在产品演进的周期中,需求表现为不同的形式:

  • 业务案例给出了主要约束,多是些可用的资源。
  • 远景文档从用户角度仅描述了系统的关键需求,它在开发过程中将缓慢演进。
  • 更详细的需求在第二阶段(细化阶段)以用例和场景的形式进行阐明,并在第三阶段(构建阶段)随着对产品和用户需求了解的加深进一步精化。这些更详细的需求记录在评估标准文档中,它们驱动了构建阶段和移交阶段迭代内容的定义, 并在迭代计划中引用。

6. Rational过程的例子 
按照2.4节中所述的区别,Rational 过程采用不同的形式。 这里有两个极端的例子。

6.1大型契约性软件开发的Rational过程 
对这个软件开发项目,Rational 过程分为3个阶段建立招标, 对应3个不同类型的合同。

  • 一个研究与设计阶段, 包含了生命周期的起始阶段和细化阶段, 通常以风险分担方式投标,举例来说,成本加奖金合同( cost plus award fee contract ,CPAF)。
  • 一个生产阶段,包含了生命周期的构建和移交阶段, 通常作为一个公司、固定的价格合同(a firm, fixed price contract ,FFP)来投标。
  • 一个维护阶段,对应生命周期的演进阶段,通常作来工作量水平合同( a level of effort contract ,LOE)来投标。

因为用户需要更高的可视性来评估项目,还因为项目涉及大量人员和组织,开发过程应更加正规化,要比小型、内部的项目更加重视书面工件。第5部分列出的11类文档都以某种形式或名称存在。

构建高效的软件开发流程

6.2小型商业软件产品的Rational过程 
在按规模分类的过程家族的另一端,是小型的商业软件开发。它的流动性更强一些,只有有限的正规性, 表现为一些主要的里程碑和有限的文档集:

  • 一个产品远景 (A product vision)。
  • 一份开发计划,显示资源和日程安排
  • 版本描述文档,在每次迭代的开始指明本次迭代的目标,在迭代结束时 作为版本说明(release notes)进行更新。
  • 必要的用户手册

软件结构、软件设计、开发过程可以通过代码本身或软件开发环境来进行文档化。

 

在项目中集成RUP和XP 构建高效的软件开发流程   构建高效的软件开发流程
构建高效的软件开发流程
构建高效的软件开发流程
构建高效的软件开发流程 概述 

我们集中讨论如何通过使用两个流行的方法得到过程的恰当级别:Rational Unified Process 或简称 RUP 以及极限编程(XP)。我们展示如何在小型项目中使用 RUP 以及 RUP 如何处理 XP 没有涉及到的领域。二者融合为项目团队提供了所需的指南–减少风险同时完成交付软件产品的目标。

RUP 是由 IBM Rational 开发的过程框架。它是一种迭代的开发方法,基于六个经过行业验证的最佳实践(参见 RUP 附录)。随着时间的推进,一个基于 RUP 的项目将经历四个阶段:起始阶段(Inception)、细化阶段(Elaboration)、构造阶段(Construction)、交付阶段 (Transition)。每个阶段都包括一次或者多次的迭代。在每次迭代中,您根据不同的要求或工作流(如需求、分析和设计等)投入不同的工作量。 RUP 的关键驱动因素就是降低风险。RUP 通过数千个项目中数千名 IBM Rational 客户和合作伙伴使用而得到精化。下图展示了一个典型迭代过程的工作流:

典型迭代流 

构建高效的软件开发流程

作为风险如何影响过程的一个例子,我们应该考虑是否需要为业务建模。如果由于对业务的理解中没有考虑到一些重大风险,将导致我们所构建的系统是错误 的,那么我们就应该执行一些业务建模工作。我们需要正式进行建模工作吗取决于我们的涉众–如果一个小团队将非正式地使用结果,那么我们也许只进行非 正式的记录就可以。如果组织中的其他人也将使用结果或者查看结果,那么我们可能就要投入更大的努力,并且确保该结果的正确性和可理解性。

您可以定制 RUP 使其满足几乎任何项目的需要。如果没有满足您特定需要的即装即用的过程或路线图,您可以轻松地创建您自己的路线图。路线图描述了该项目如何计划使用过程, 因此代表了该项目的特定过程实例。这就意味着,RUP 可以按需要变得简单或复杂,我们将在本文中详细解释。

XP 是一个用于小型项目中的以代码为中心的轻量级过程(参见 XP 附录)。它来自 Kent Beck 的创意,在大概 1997 年 Chrysler 公司的 C 3 工资单项目中得到软件界的关注。如同 RUP 一样,XP 也是基于迭代的,并且体现了诸如小规模发布、简单设计、测试以及持续迭代几项实践,。XP 为恰当的项目和环境引入了一些有效的技术;不过,其中也存在隐藏的假设、活动和角色。

RUP 和 XP 具有不同的基本原理。RUP 是过程组件、方法以及技术的框架,您可以将其应用于任何特定的软件项目,我们希望用户限定 RUP 的使用范围。XP,从另一方面来说,是一个具有更多限制的过程,需要附加内容以使其适合完整的开发项目。这些不同点解释了软件开发界的一个观点:开发大型 系统的人员使用 RUP 解决问题,而开发小型系统的人员使用 XP 作为解决方案。我们的经验表明大部分的软件项目都处于两者之间–尽力找寻适用于各自情况的过程的恰当级别。单纯地使用两者之一是不充分的。

当您在 RUP 中融合了 XP 技术时,您会得到过程的正确量,既满足了项目所有成员的需要,又解决了所有主要的项目风险问题。对于一个工作于高信任环境中的小型项目团队,其中用户是团 队的一部分,那么 XP 完全可以胜任。对于团队越来越分散,代码量越来越大,或者构架没有很好定义的情况,您需要做一些其他工作。在用户交互具有”契约”风格的项目中,仅有 XP 是不够的。RUP 是一个框架,您可以从 RUP 出发,在必要时以一组更健壮的技术来扩展 XP。

本文的以下部分描述了一个基于 RUP 四个阶段的小型项目。在每个阶段中,我们都确定了所产生的活动和工件 。虽然 RUP 和 XP 具有不同的角色和职责,但是我们在这里不会处理这些差异。对于任何组织或项目,实际项目成员必须在过程中与正确的角色关联起来。

项目启动-起始阶段 
对于新的开发项目来说,起始阶段是很重要的,在项目继续进行前,您必须处理重要的业务与需求风险。对于那些增强现有系统的项目,起始阶段是比较短暂的,但是其目的仍是确定该项目的实施价值及可行性。

在起始阶段中,为了构建软件您可以创建业务案例。视图是起始过程中的关键工件。它是系统的高级描述。它为每个人解释该系统是什么、可能使用系统的用 户、使用系统的原因、必须具备的功能,以及存在的约束。视图可能很短,也许只有一两段。视图往往包括软件必须为客户提供的关键功能。

下面的例子展示了一个项目的很短视图,该项目对 Rational 的外部网站进行了改造。

为使 Rational 的地位达到电子开发(包括工具、服务和最佳实践)的世界领先程度,可以通过动态的、个性化的网站加强客户关系,为访问者提供自助服务、支持和目标内容。新的过程和技术启用可以使内容供应商通过一种简化的、自动的解决方案加速发布并提高内容的质量。

RUP 起始阶段中 4 个重要活动为:

制定项目的范围。如果我们打算构建一个系统,我们需要知道其内容以及它如何满足涉众的需要。在这个活动中,我们捕获内容和最重要的需求的足够详细的信息,从而得出产品可接受的标准。

计划并准备业务案例。我们使用视图作为指导,定义风险缓和策略,开发起始的项目计划,并确定已知成本、日程计划,以及盈利率平衡。

综合得出备选构架。如果正在计划中的系统没什么新颖性,而且使用的框架广为人之,那么您可以跳过这一步。我们一旦知道客户的需求,就要开始分配时间 研究可行的备选构架。新技术能够带来解决软件问题的新的并且经过改进的解决方案。在过程的早期花些时间评估购买还是创建系统,并选择技术,也可以开发出一 个起始原型,这些都可以减少项目的一些主要风险。

准备项目环境。任何项目都需要项目环境。不论您使用 XP 技术(例如结对编程),还是较传统的技术,您都需要确定团队将要使用的物理资源、软件工具以及步骤。

进行小型项目开发时,并不需要太多的”过程时间”来执行起始过程。您往往可以在几天中或者更少的时间里完成,下面的内容说明了本阶段除了视图之外的预期工件。

一个经批准的业务案例 
涉众有机会 从业务的角度认定项目是值得进行的。RUP 和 XP 都承认最好在早期就得出项目是否值得进行的结论,以免在一个注定将要失败的项目中花费宝贵的资源。如同在”Planning Extreme Programming” 一书描述的那样,XP 对于项目是如何形成的以及涉及哪些角色这两个问题的回答是比较模糊的(似乎在现有项目或系统的环境中是最清晰的),但是在研究阶段,XP 处理的工件与 RUP 起始过程中的是相同的。

不论您在 XP 中非正式地考虑业务问题,还是在 RUP 中将业务案例做成一流的项目工件,您都需要考虑这些问题。风险清单您应该在整个项目开发过程中都保持记录 Risk List(风险清单)。使用有风险清单可以是一个具有经过计划的风险缓和策略的简单清单。为各个风险设定优先级。任何与项目有关的人员都可以随时看到风险 的内容以及如何处理风险,但是没有提供解决风险的一般方式 。

初步项目计划 
本计划包括资源估算、规模以及阶段计划。对于任何项目,这些估算都是不断变化的,您必须监控它们。

项目验收计划 
您的计划正式与否依 赖于项目的类型。您必须判断客户会如何才能认为您的项目取得了成功。对于一个 XP 项目,客户会采取验收测试的形式。在更普遍的过程中,客户可能不会真正地进行测试,但是接受的标准必须直接由客户作出,或者由另一个角色作出,例如与客户 直接接触的系统分析员。也可能存在其他的验收标准,例如创建最终用户文档和帮助,但是XP并不涉及此内容。

起始细化迭代计划 
在基于 RUP 的项目中,在上次迭代的最后,您将详细计划下次迭代。在迭代的最后,您可以评估迭代开始时设立的标准。XP 提供了探监控与衡量迭代成功的一些优秀技巧。衡量标准是简单的,您可以轻松地将它们合并到迭代计划和评估标准中。

起始用例模型 
虽然这听起来比较正 式而让人望之却步,但是它却相当简单。用例与客户在XP中编写的”故事”相对应。其间的差异就是一个用例就是一套完整的动作,由参与者或系统外部的人员或 事物发起,这正是用例的价值所在。用例可能包括若干个XP”故事”。RUP 为了定义项目的边界,推荐在起始过程中确定用户与角色。从用户的观点关注整套操作有助于将系统分为有价值的部分。这有助于判定恰当的实施特性,因此我们能 够在每次迭代的最后向客户交付一些成果(可能在起始迭代与细化迭代早期除外)。

RUP 与 XP 都可以帮助我们确保避免一种情况,即整个项目已完成 80%,但都不是可交付的形式。我们一直希望发布的系统对用户都是有价值的。

在这一点上,用例模型在识别用例和参与者方面几乎没有或只有很少提供支持的细节。它可以是手工或使用工具绘制的简单的文本或者 UML(统一建模语言)图。该模型帮助我们确保已经包含了涉众所关心的正确的功能,并且没用忘记任何功能,并允许我们轻松地查看整个系统。用例根据若干因 素设定优先级,这些因素包括风险、对客户的重要程度以及技术难点。起始阶段中不需要过于正式的或过大的工件。按照您的需求让它们保持简单或者正式就可以。 XP 包括对计划与系统验收的指南,但是 RUP 需要在项目的早期添加更多的一些内容。这些少量添加可能通过处理一套更完整的风险而为项目提供很大的价值。

细化阶段 
细化阶段的目标是为系统构架设立基线,为在构建阶段大量的设计与实施工作打下坚实的基础。构架通过考虑最重要的需求(那些对系统构架影响最大的需求)与评估风险演进而来。构架的稳定性是通过一个或多个构架原型进行评估的。

在 RUP 中,设计活动主要关注系统构架的概念,对于软件密集型的系统来说,就是软件构架的概念。使用组件构架是在 RUP 中体现的软件开发 6 项最佳实践其中之一,该实践推荐在开发与所作所为构架上要投入一些时间。在这项工作花费的时间可以减缓与脆弱的、僵化日系统有关的风险。

XP 使用”隐喻”替换了构架的概念。隐喻只捕获构架的一部分,而其余构架部分则随着代码开发的自然结果而演进。XP假定构架的形成是从生成简单的代码开始,然后进行持续的代码重构。

在 RUP 中,构架不只是”隐喻”。在细化阶段中,您构建可执行的构架,从中可能降低与是否满足非功能性需求相关的许多风险,例如性能、可靠性以及健壮性。通过阅读 XP文献,很可能推断出一些 RUP 为细化阶段所描述的内容,尤其是过于 XP 所称的基础设施的过分关注,都是徒劳无功的。XP 认为在没有必要的情况下创建基础设施所做的工作导致了解决方案过于复杂,并且所创建的结果对客户没有价值。在 RUP 中,构架与基础设施不是等同的。

在 RUP 与 XP 中创建构架的方法是截然不同。RUP 建议您关注构架,避免随时间变化

来源:automationer

声明:本站部分文章及图片转载于互联网,内容版权归原作者所有,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2012年6月16日
下一篇 2012年6月16日

相关推荐