简单理解敏捷开发

          看了很多内容,终于对敏捷开发内容有所了解。简单来说,敏捷开发就是指你开发的东西能马上让用户用到,在用户使用的过程中继续开发其他的一些功能。

          相对于传统的瀑布开发来说,敏捷更注重的是以人为本。

          一、客户。要求尽早让客户看到结果,然后不断改进,直到合适。

          二、开发人员。充分调动开发人员积极性,让每个人觉得自己做的事情有意义。

  

以下是引用的敏捷开发原文

------------------------------------------------------------------------------------------------------------------------------------

敏捷开发(agile development)概念从2004年初开始广为流行。Bailar非常支持这一理论,他采取了"敏捷方式"组建团队:Capital One的"敏捷团队"包括3名业务人员、两名操作人员和5~7名IT人员,其中包括1个业务信息指导(实际上是业务部门和IT部门之间的"翻译者");另外,还有一个由项目经理和至少80名开发人员组成的团队。这些开发人员都曾被Bailar送去参加过"敏捷开发"的培训,具备相关的技能。

每个团队都有自己的敏捷指导(Bailar聘用了20个敏捷指导),他的工作是关注流程并提供建议和支持。最初提出的需求被归纳成一个目标、一堆记录详细需要的卡片及一些供参考的原型和模板。在整个项目阶段,团队人员密切合作,开发有规律地停顿--在9周开发过程中停顿3~4次,以评估过程及决定需求变更是否必要。在Capital One,大的IT项目会被拆分成多个子项目,安排给各"敏捷团队",这种方式在"敏捷开发"中叫"蜂巢式(swarming)",所有过程由一名项目经理控制。

为了检验这个系统的效果,Bailar将项目拆分,从旧的"瀑布式"开发转变为"并列式"开发,形成了"敏捷开发"所倡导的精干而灵活的开发团队,并将开发阶段分成30天一个周期,进行"冲刺"--每个冲刺始于一个启动会议,到下个冲刺前结束。

在Bailar将其与传统的开发方式做了对比后,他感到非常兴奋--"敏捷开发"使开发时间减少了30%~40%,有时甚至接近50%,提高了交付产品的质量。"不过,有些需求不能用敏捷开发来处理。" Bailar承认,"敏捷开发"也有局限性,比如对那些不明确、优先权不清楚的需求或处于"较快、较便宜、较优"的三角架构中却不能排列出三者优先级的需求。此外,他觉得大型项目或有特殊规则的需求的项目,更适宜采用传统的开发方式。尽管描述需求一直是件困难的事,但经过阵痛之后,需求处理流程会让CIO受益匪浅。

敏捷开发是由一些业界专家针对一些企业现状提出了一些让软件开发团队具有快速工作、响应变化能力的价值观和原则,并于2001初成立了敏捷联盟。他们正在通过亲身实践以及帮助他人实践,揭示更好的软件开发方法。通过这项工作,他们认为:

个体和交互 胜过 过程和工具
可以工作的软件 胜过 面面俱到的文档
客户合作 胜过 合同谈判
响应变化 胜过 遵循计划
并提出了以下遵循的原则:

我们最优先要做的是通过尽早的、持续的交付有价值的软件来使客户满意。
即使到了开发的后期,也欢迎改变需求。敏捷过程利用变化来为客户创造竞争优势。
经常性地交付可以工作的软件,交付的间隔可以从几个星期到几个月,交付的时间间隔越短越好。
在整个项目开发期间,业务人员和开发人员必须天天都在一起工作。
围绕被激励起来的个体来构建项目。给他们提供所需的环境和支持,并且信任他们能够完成工作。
在团队内部,最具有效果并富有效率的传递信息的方法,就是面对面的交谈。
工作的软件是首要的进度度量标准。
敏捷过程提倡可持续的开发速度。责任人、开发者和用户应该能够保持一个长期的、恒定的开发速度。
不断地关注优秀的技能和好的设计会增强敏捷能力。
简单是最根本的。
最好的构架、需求和设计出于自组织团队。
每隔一定时间,团队会在如何才能更有效地工作方面进行反省,然后相应地对自己的行为进行调整。

一、敏捷开发方法

(一) 说明
本文是阅读Alistair Cockburn的Agile Software Development和William C. Wake的XP Explored的一些笔记和想法,Agile Software Development是一组软件开发方法的总称,包括(Crystal , Extreme Programming , Adaptive software development等等)。敏捷开发方法又称为“轻量级”开发方法。

下面这段话摘自Martin Fowler的一篇文章:

从无到繁重再到敏捷
多数软件开发仍然是一个显得混乱的活动,即典型的“边写边改” (code and fix)。设计过程充斥着短期的,即时的决定,而无完整的规划。这种模式对小系统开发其实很管用,但是当系统变得越大越复杂时,要想加入新的功能就越来越困难。同时错误故障越来越多,越来越难于排除。一个典型的标志就是当系统功能完成后有一个很长的测试阶段,有时甚至有遥遥无期之感,从而对项目的完成产生严重的影响。
我们使用这种开发模式已有很长时间了,不过我们实际上也有另外一种选择,那就是“正规方法”(methodology)。这些方法对开发过程有着严格而详尽的规定,以期使软件开发更有可预设性并提高效率,这种思路是借鉴了其他工程领域的实践。
这些正规方法已存在了很长时间了,但是并没有取得令人瞩目的成功,甚至就没怎么引起人们的注意。对这些方法最常听见的批评就是它们的官僚繁琐,要是按照它的要求来,那有做太多的事情需要做,而延缓整个开发进程。所以它们通常被认为是“繁琐滞重型”方法,或Jim HighSmith 所称的“巨型”(monumental)方法。
作为对这些方法的反叛,在过去几年中出现了一类新方法。尽管它们还没有正式的名称,但是一般被称为“敏捷型”方法。对许多人来说,这类方法的吸引之处在于对繁文缛节的官僚过程的反叛。它们在无过程和过于繁琐的过程中达到了一种平衡,使得能以不多的步骤过程获取较满意的结果。
敏捷型与滞重型方法有一些显著的区别。其中一个显而易见的不同反映在文档上。敏捷型不是很面向文档,对于一项任务,它们通常只要求尽可能少的文档。从许多方面来看,它们更象是“面向源码”(code-oriented)。事实上,它们认为最根本的文档应该是源码。
但是,我并不以为文档方面的特点是敏捷型方法的根本之点。文档减少仅仅是个表象,它其实反映的是更深层的特点:
? 敏捷型方法是“适配性”而非“预设性”。 重型方法试图对一个软件开发项目在很长的时间跨度内作出详细的计划,然后依计划进行开发。这类方法在计划制定完成后拒绝变化。而敏捷型方法则欢迎变化。其实,它们的目的就是成为适应变化的过程,甚至能允许改变自身来适应变化。
? 敏捷型方法是“面向人”的(people-oriented) 而非“面向过程”的 (process-oriented)。 它们试图使软件开发工作顺应人的天性而非逆之。它们强调软件开发应当是一项愉快的活动。
我认为以上两个特点很好的概括了敏捷开发方法的核心思想:适应变化和以人为中心

(二) 方法背后的思想

Alistair Cockburn在Agile Software Development中讲述了敏捷开发方法背后的思想

人们掌握过程(process)可以分为3个阶段:
1 following 遵循一个定义好的process
2 detaching 知道不同process的适用范围,在不同的场合使用不同的process
3 fluent 不关心是否遵循特定的process,知道在什么情况下采用什么动作

软件开发是一个充满发明和交流的协作性游戏(cooperative game of invertion and communication)。软件开发的首要目标是生产出软件,遵循特定的过程和模型只是手段,只要传递了足够的信息,手段是次要的。交流的效果要远远重于交流的形式(Effect of communication is more important than the form of communication)。
一般软件开发有两个目标:1 尽快的生产出软件2 为下一个team或项目做准备,有时这两个目标是矛盾的,我们要在这两个目标之间寻求平衡

在软件开发中,人的因素要远远大于过程和技术。人是有缺陷的:
1 容易犯错误,因此必须在错误扩散之前找到并改正错误
2 当觉得可能失去较多的时候,不愿意冒险
3 重新构造而不愿意重复使用已有的东西
4 难于坚持一个习惯

针对个人因素的几个建议:
1 具体的模型较抽象的模型更容易理解
2 从一个例子开始是容易的
3 通过观察他人的成果学习
4 要有足够的不受打扰的时间
5 分配的工作要与个人意向,能力匹配
6 不正确的奖励会有坏作用,从长期看个人兴趣比奖励更重要,培养在工作中的自豪感:
1) pride in work参与工作的自豪感,通常参与一个重要的工作会有自豪感
2) pride in accomplishment 完成工作的自豪感,长期未完的工作会使士气低落
3)pride in contribution 为他人贡献的自豪感
7 鼓励关心其他人的工作和整体的工作

在一个团队之间,交流是最重要的,实践证明面对面的实时的交流是最有效的,对交流的延误会损失信息,白板是最好的交流工具,交流工具的先进并不能提高交流效果。文档的作用是记录和备忘,不能通过文档交流。

敏捷开发方法要避免的过程设计的几个常见错误
1 对所有的项目使用同一种过程
2 没有弹性
3 过于沉重
4 增加不必要的“必须完成”(“should do” is really should?)
5 没有经过实践检验

敏捷开发方法过程设计的几个原理:
1 交互的面对面的交流是代价最小,最迅速的交换信息的方法
2 超过实际需要的过程是浪费的
3 大的团队需要重量级方法
4 处理重大问题的项目需要重量级方法强调
5 增加反馈和交流可以减少中间产品和文档的需求
6 轻量级方法更强调理解(understanding),自律(discipline)和技能(skill),重量级方法更强调文档(documentation),过程(process)和正式(formality)
understanding指整个团队关于项目的全部知识,包括讨论的过程,documentation只能记录其中的一部分
discipline是指个人主动的完成工作,process指个人根据指令完成工作
skill指具有良好技能的人可以省略中间的产品,formality指必须按照规定步骤完成工作

7 确定开发中间的瓶径,提高它的效率
对于瓶径处的工作应该尽量加快,减少重复,(使用更熟练的人,使用更多的人,使用更好的工具,使瓶径处的工作的深入尽量稳定)对于非瓶径处的工作可以多一些重复,在输入还不确定的情况下也可以尽早开始。

这些原理的几个结论:
1 向一个项目增加人员要花费较大代价(constly),因为原有人员和新人员之间的交流要花费大量时间
2 团队的规模经常是跳跃的,例子:需要6个熟练的程序员,但是只有4个,于是增加不熟练的程序员,结果团队的大量时间花费在培训不熟练的程序员上面,最后增加到了20个不熟练的程序员。
3 应该侧重于提高团队的技能而不是扩充团队
4 对不同的项目使用不同的过程
5 在适用的条件下,轻量级的方法优于重量级的方法
6 对不同的项目要裁减过程

敏捷开发方法的原则是“刚刚好”(Light and Sufficient)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
选课系统是现代高校管理中重要的组成部分,其顺畅运行对于学生和教职工的学习和教学具有重要意义。本文将从选课系统的执行控制过程入手,探究如何进行迭代开发和管理,以实现选课系统的高效运转。 一、迭代开发与管理 迭代开发是一种敏捷软件开发方法,它强调的是在整个开发过程中,不断进行迭代,每个迭代都包含设计、开发、测试和评审等流程。而迭代开发的核心思想是“快速响应变化”,即在面对需求变更时,能够快速响应并进行调整。 在选课系统的开发中,迭代开发可以帮助开发团队更快速地响应用户需求和变化,同时保证软件质量和用户体验。下面,我们将详细讲解迭代开发的具体流程。 1. 选择本迭代内容,进行任务再分配 在每个迭代开始前,开发团队需要先确定本次迭代的主要内容和目标,进而对任务进行再分配。通常情况下,每个迭代的时间较短,一周或两周为宜。 在任务分配时,需要考虑到团队成员的技能和经验,以确定每个人的任务分配。同时,还要考虑到任务的紧急程度和优先级,以确保能够在规定的时间内完成任务。 2. 进行简单设计 在确定了本次迭代的内容后,需要进行简单的设计,以明确所需功能和流程,并为后续开发提供基础支持。设计的目的是为了确保团队成员有一个清晰的目标,同时也可以帮助团队成员减少不必要的开发时间和成本。 在进行设计时,需要明确需求,建立一个简单的模型,并考虑如何实现这个模型。设计的过程中,需要注意以下几点: (1)尽可能地简化设计,减少不必要的复杂性; (2)遵循设计原则,如开闭原则、单一职责原则等; (3)考虑可扩展性和可维护性,确保后续开发和维护的顺畅进行。 3. 设计测试用例 在进行开发之前,需要对设计的功能进行测试,以确保软件的质量和可靠性。测试的目的是为了发现和修复软件中的缺陷和问题,在软件发布前保证其质量。 在设计测试用例时,需要考虑以下几点: (1)测试用例必须覆盖所有的功能需求; (2)测试用例必须具有可重复性,以确保测试结果的准确性; (3)测试用例必须简单明了,易于理解和实施。 4. 敏捷开发过程,实施结对编程 在进行开发时,采用敏捷开发过程是非常重要的。敏捷开发过程强调的是团队合作、快速响应和不断迭代的思想,可以帮助团队更快速地响应变化和需求。 在开发过程中,可以采用结对编程的方式来提高效率和质量。结对编程可以让两个开发人员共同完成一个任务,互相review代码,确保代码质量和可读性。 5. 提交本迭代的版本,实现持续交付 在每个迭代完成后,需要将版本提交到版本控制系统中,并实现持续交付。持续交付可以帮助团队更快速地发布新功能和修复缺陷,提高软件的可靠性和稳定性。 6. 持续测试,记录缺陷 在迭代过程中,需要进行持续测试,及时发现和修复缺陷。持续测试可以帮助团队更快速地发现问题,并及时进行调整。 同时,还需要记录缺陷和问题,以便后续进行跟踪和解决。记录缺陷的过程中,需要包括缺陷的类型、严重程度、解决方案等信息。 7. 根据开发逐步完善设计、需求 在开发过程中,需求和设计可能会发生变化,因此需要根据开发情况逐步完善设计和需求。在迭代过程中,需要及时与用户进行沟通和反馈,以确保软件满足用户需求和期望。 8. 例会,通过任务看板跟踪项目进度 在每个迭代结束后,需要进行例会,通过任务看板跟踪项目进度。例会可以帮助团队成员更好地了解项目进度和任务分配情况,及时发现和解决问题。 任务看板可以帮助团队成员更好地掌握任务的进度和优先级,及时调整任务分配和处理任务之间的依赖关系。 9. 迭代评审 在每个迭代结束后,需要进行迭代评审。迭代评审的目的是为了评估本次迭代的效果和成果,并为下一次迭代提供参考和改进意见。 在迭代评审中,需要评估本次迭代的进度、质量和效果,分析问题和改进方案,并确定下一次迭代的目标和计划。 二、总结 在选课系统的开发中,迭代开发可以帮助团队更快速地响应变化和需求,同时保证软件的质量和用户体验。迭代开发的过程包括了任务再分配、简单设计、设计测试用例、敏捷开发过程、持续交付、持续测试、逐步完善设计和需求、通过任务看板跟踪项目进度和迭代评审等环节。 在实际开发中,需要根据具体情况进行调整和改进,以满足项目的实际需求和情况。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值