从一个项目谈XP在国内的应用(2)(转)

每周40小时工作制 ( 40-hour Week )
  · XP: 要求项目团队人员每周工作时间不能超过40小时,加班不得连续超过两周,否则反而会影响生产率。
  · 评述: 该实践充分体现了XP的"以人为本"的原则。但是,如果要真正的实施下去,对于项目进度和工作量合理安排的要求就比较高。
  · 项目: 由于项目的工期比较充裕,因此,很幸运的是我们并没有违反该实践。
计划博弈 ( Planning Game )
  XP: 要求结合项目进展和技术情况,确定下一阶段要开发与发布的系统范围。
  · 评述: 项目的计划在建立起来以后,需要根据项目的进展来进行调整,一成不变的计划是不存在。因此,项目团队需要控制风险、预见变化,从而制定有效、可行的项目计划。
  · 项目: 在系统实现前,我们首先按照需求的优先级做了迭代周期的划分,将高风险的需求优先实现;同时,项目团队每天早晨参加一个15分钟的项目会议,确定当天以及目前迭代周期中每个成员要完成的任务。
系统隐喻 ( System Metaphor )
  · XP: 通过隐喻来描述系统如何运作、新的功能以何种方式加入到系统。它通常包含了一些可以参照和比较的类和设计模式。XP不需要事先进行详细的架构设计。
  · 评述: XP在系统实现初期不需要进行详细的架构设计,而是在迭代周期中不断的细化架构。对于小型的系统或者架构设计的分析会推迟整个项目的计划的情况下,逐步细化系统架构倒是可以的;但是,对于大型系统或者是希望采用新架构的系统,就需要在项目初期进行相信的系统架构设计,并在第一个迭代周期中进行验证,同时在后续迭代周期中逐步进行细化。
  · 项目: 开发团队在设计初期,决定参照STRUTS框架,结合项目的情况,构建了针对工作流程处理的项目框架。首先,团队决定在第一个迭代周期实现配件申请的工作流程,在实际项目开发中验证了基本的程序框架;而后,又在其它迭代周期中,对框架逐渐精化。
简单设计 ( Simple Design )
  · XP: 认为代码的设计应该尽可能的简单,只要满足当前功能的要求,不多也不少。
  · 评述: 传统的软件开发过程,对于设计是自顶而下的,强调设计先行,在代码开始编写之前,要有一个完美的设计模型。它的前提是需求不变化,或者很少变化;而XP认为需求是会经常变化的,因此设计不能一蹴而就,而应该是一项持续进行的过程。
  Kent Beck认为对于XP来说,简单设计应该满足以下几个原则:
  1.成功执行所有的测试;
  2.不包含重复的代码;
  3.向所有的开发人员清晰地描述编码以及其内在关系;
  4.尽可能包含最少的类与方法。
  对于国内大部分的软件开发组织来说,应该首先确定一个灵活的系统架构,而后在每个迭代周期的设计阶段可以采用XP的简单设计原则,将设计进行到底。
  · 项目: 在项目的系统架构经过验证后的迭代周期内,我们始终坚持简单设计的原则,并按照Kent Beck的四项原则来进行有效的验证。对于新的迭代周期中出现需要修改既有设计与代码的情况,首先对原有系统进行"代码重构",而后再增加新的功能。
测试驱动 ( Test-driven )
  · XP: 强调"测试先行"。在编码开始之前,首先将测试写好,而后再进行编码,直至所有的测试都得以通过。
  · 评述: RUP与XP对测试都是非常的重视,只是两者对于测试在整个项目开发周期内首先出现的位置处理不同。XP是一项测试驱动的软件开发过程,它认为测试先行使得开发人员对自己的代码有足够的信心,同时也有勇气进行代码重构。测试应该实现一定的自动化,同时能够清晰的给出测试成功或者失败的结果。在这方面,xUnit测试框架做了很多的工作,因此很多实施XP的团队,都采用它们进行测试工作。
  · 项目: 我们在项目初期就对JUNIT进行了一定的研究工作,在项目编码中,采用JBUILDER6提供的测试框架进行测试类的编写。但是,不是对所有的方法与用例都编写,而只是针对关键方法类、重要业务逻辑处理类等进行。
代码重构 ( Refactoring )
  · XP: 强调代码重构在其中的作用,认为开发人员应该经常进行重构,通常有两个关键点应该进行重构:对于一个功能实现和实现后。
  · 评述: 代码重构是指在不改变系统行为的前提下,重新调整、优化系统的内部结构以减少复杂性、消除冗余、增加灵活性和提高性能。重构不是XP所特有的行为,在任何的开发过程中都可能并且应该发生。
  在使用代码重构的时候要注意,不要过分的依赖重构,甚至轻视设计,否则,对于大中型的系统而言,将设计推迟或者干脆不作设计,会造成一场灾难。
  · 项目: 我们在项目中将JREFACTORY工具部署到JBuilder中进行代码的重构,重构的时间是在各个迭代周期的前后。代码重构在项目中的作用是改善既有设计,而不是代替设计。
成对编程 ( Pair Programming )
  · XP: 认为在项目中采用成对编程比独自编程更加有效。成对编程是由两个开发人员在同一台电脑上共同编写解决同一问题的代码,通常一个人负责写编码,而另一个负责保证代码的正确性与可读性。
  · 评述: 其实,成对编程是一种非正式的同级评审 ( Peer Review )。它要求成对编程的两个开发人员在性格和技能上应该相互匹配,目前在国内还不是十分适合推广。成对编程只是加强开发人员沟通与评审的一种方式,而非唯一的方式。具体的方式可以结合项目的情况进行。
  · 项目: 我们在项目中并没有采用成对编程的实践,而是在项目实施的各个阶段,加强了走查以及同级评审的力度。需求获取、设计与分析都有多人参与,在成果提交后,交叉进行走查;而在编码阶段,开发人员之间也要在每个迭代周期后进行同时评审。
  · XP: 认为开发小组的每个成员都有更改代码的权利,所有的人对于全部代码负责。
  · 评论: 代码全体拥有并不意味者开发人员可以互相推委责任,而是强调所有的人都要负责。如果一个开发人员的代码有错误,另外一个开发人员也可以进行BUG的修复。
  在目前,国内的软件开发组织,可以在一定程度上实施该实践,但是同时需要注意一定要有严格的代码控制管理。
  · 项目: 我们在项目开发初期,首先向开发团队进行"代码全体拥有"的教育,同时要求开发人员不仅要了解系统的架构、自己的代码,同时也要了解其它开发人员的工作以及代码情况。这个实践与同级评审有一定的互补作用,从而保证人员的变动不会对项目的进度造成很大的影响。
  在项目执行中,有一个开发人员由于参加培训,缺席项目执行一周,由于实行了"代码全体拥有"的实践,其它的开发人员成功地分担了该成员的测试与开发任务,从而保证项目的如期交付。
持续集成 ( Continuous Integration )
  · XP: 提倡在一天中集成系统多次,而且随着需求的改变,要不断的进行回归测试。因为,这样可以使得团队保持一个较高的开发速度,同时避免了一次系统集成的恶梦。
  · 评述: 持续集成也不是XP专有的最佳实践,著名的微软公司就有每日集成 ( Daily Build ) 的成功实践。但是,要注意的是,持续集成也需要良好的软件配置变更管理系统的有效支持。
  · 项目: 使用VSS作为软件配置管理系统,坚持每天进行一次的系统集成,将已经完成的功能有效地结合起来,进行测试。
小型发布 ( Small Release )
  · XP: 强调在非常短的周期内以递增的方式发布新版本,从而可以很容易地估计每个迭代周期的进度,便于控制工作量和风险;同时,也可以及时处理用户的反馈。
  · 评论: 小型发布突出体现了敏捷方法的优点。RUP强调迭代式的开发,对于系统的发布并没有作出过多的规定。用户在提交需求后,只有在部署时才能看到真正的系统,这样就不利于迅速获得用户的反馈。
  如果能够保证测试先行、代码重构、持续集成等最佳实践,实现小型发布也不是一件困难的事情,在有条件的组织可以考虑使用。
  · 项目: 项目在筹备阶段就配置了一台测试与发布服务器,在项目实施过程中,平均每两周(一个迭代周期结束后)进行一个小型发布;用户在发布后两个工作日内,向项目小组提交"用户接收测试报告",由项目经理评估测试报告,将有效的BUG提交至Rational Clear Case,并分配给相应的开发人员。项目小组应该在下一个迭代周期结束前修复所有用户提交的问题。
  以上是XP的最佳实践在项目中的应用情况,让我们查看以下该项目的详细统计数据:
xpyy3.gif
  其中,项目执行过程中提交了一个"用户需求变更",该变更对于项目周期的影响为6个工作日。
  项目实施后,在用户接收测试中,只提交了2个BUG,而且在提交当天就得到了解决。目前,项目运行平稳,并得到了用户的好评。因此,我们认为,XP在该项目中的实施有效地保证了项目质量和项目周期。
总结
  RUP与XP 都是在总结了很多项目实践的过程中发展起来的软件开发过程, 只是它们在处理需求变更的方法不同。其实它们还是有很多相似之处,例如,它们的基础都是面向对象方法,都重视代码、文档的最小化和设计的简化,采用动态适应变化的演进式迭代周期等等。
  目前,国内执行XP的理想情况应该是:在保持组织既有的开发过程和生命周期模型的情况下,根据应用类型、项目特点和组织文化,借鉴、采取个别对项目有效的XP做法,将RUP进行一定的剪裁,形成自己的软件开发过程。
  在项目的实施过程中,我们感觉到XP对于执行者的要求是比较高的,因为它要求开发团队必须具备熟练的代码设计技能和严格的测试保障技术,了解面向对象和模式,掌握了重构和OO测试技术,习惯了测试先行的开发方式等等。
  因此,对于目前国内的软件开发组织来说,应该首先加强对于软件开发过程化和系统架构设计的掌握,然后,才是利用XP等敏捷方法来完善软件开发过程。
参考文献
  [1] Software Engineering a Practitioner’s Approach ( Fifth Edition) Roger S. Pressman
  [2] Is Design Dead Martin Fowler
  [3] XP Explored William C. Wake
  [4] XP Distilled Christopher T. Collins, Roy W. Miller
  [5] XP的价值和局限 X-Programmer 15 张恂
作者简介:
  曲俊生,Ion Global 软件工程师。有近5年的软件开发经验,尤其擅长网络应用程序的开发。目前他的研究与开发兴趣在J2EE, XP, Refactoring 以及Design Pattern。目前居住在上海,喜欢爬山、旅游等休闲活动。
[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/7839396/viewspace-958479/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/7839396/viewspace-958479/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值