敏捷的方法与误区

如今越来越多的事情被定义为“敏捷”,尤其是那些试图向我们出售产品的人。如果我们问造纸厂商什么是“敏捷”,他们可能会说,如果买了他们的纸,在纸上写下用户故事就是“敏捷”;如果问咨询顾问,可能会听到,“敏捷”是一种开发软件的方法,如果购买了他们的服务,那团队就可以学习到这种方法;如果跟鞋的厂商交谈,他们可能会说,“敏捷”的关键是开会的时候每个人都要站起来,所以你的鞋子越舒服,团队就会越“敏捷”……

什么是敏捷?

事实上,大多数宣称自己是“敏捷”的事物,实际上并不是“敏捷”。“敏捷”的实际定义来自敏捷宣言,宣言明确表明了“敏捷”不是一种方法论,也不是进行软件开发的特定方法,更不是一个框架或流程。

敏捷实际上是一套价值观和原则,围绕它大部分的讨论,都与各种理论方法,甚至特定的敏捷开发软件有关,尽管这些东西可能会帮助一个团队建立“敏捷”,但这些方法和工具本身并非“敏捷”。

例如,举行每日站立会议可能会对团队很有帮助,但之所以有这种会议形式,只是因为团队遵循了“敏捷”的原则和价值观。这很容易就能看出,敏捷实际上就是一系列理念,在软件开发工作中,团队可以用这些理念来更好地做决策。

敏捷宣言

我们一直在实践中探寻更好的软件开发方法,身体力行,同时也帮助他人。由此我们建立了如下价值观:

个体和互动高于流程和工具

工作的软件高于详尽的文档

客户合作高于合同谈判

响应变化高于遵循计划

也就是说,尽管右项有其价值,但更重视左项的价值。

敏捷开发12条原则

  1. 我们最重要的目标,是通过及早和持续不断地交付有价值的软件使客户满意。
  2. 欣然面对需求变化,即使在开发后期也一样。为了客户的竞争优势,敏捷过程掌控变化。
  3. 经常地交付可工作的软件,相隔几星期或一两个月,倾向于采取较短的周期。
  4. 业务人员和开发人员必须相互合作,项目中的每一天都不例外。
  5. 激发个体的斗志,以他们为核心搭建项目。提供所需的环境和支援,辅以信任,从而达成目标。
  6. 不论团队内外,传递信息效果最好效率也最高的方式是面对面的交谈。
  7. 可工作的软件是进度的首要度量标准。
  8. 敏捷过程倡导可持续开发。责任人、开发人员和用户要能够共同维持其步调稳定延续。
  9. 坚持不懈地追求技术卓越和良好设计,敏捷能力由此增强。
  10. 以简洁为本,它是极力减少不必要工作量的艺术。
  11. 最好的架构、需求和设计出自组织团队。
  12. 团队定期地反思如何能提高成效,并依此调整自身的行为表现。

敏捷的方法与误区

敏捷实际上是开发过程中做决策的最好基础。例如,一个程序员正在为客户开发一个产品功能,但是要实现这个功能,首先需要一个数据库。如果这个程序员信奉“敏捷”的价值观并试图遵循“敏捷”的原则,他会认为建立新的数据库意味着,这个产品将不得不延迟交付给客户,如果能找到一种方法,来解决开发此功能所需的数据库支持,那这个方法会更好地符合我的原则。

工作中,大家一旦了解到强大的“敏捷”团队是如何工作的,就会很容易去模仿他们的做法,然而这种方法并不会让团队变得更“敏捷”,与其模仿,不如去了解他们为什么用这种方法工作。

随着时间的推移,一个优秀的“敏捷”团队,可能会不断完善团队之间合作的方法。比如,一个团队最开始可能用“Scrum”模式,后来发现“看板”是一种更好地向客户交付价值的方法;另一个团队开始用敏捷扑克牌估算估算任务工时,代替了故事点的方式。所以敏捷开发模式要根据自己的实际情况去运用,而不是简单去套用别人的“敏捷”实践。

遵循“敏捷”的原则和价值观,才能变成敏捷团队,如果你选择了某种实践,是因为它遵循了“敏捷”原则,这可能是一个不错的起点。如果原则是错误的,即使是一样的实践也并非会带来好的结果。

敏捷的价值观和原则具有足够的灵活性,可以让不同类型的团队,以最适合其特定情况的方式去进行项目的开展,帮助团队不断朝着自己的方向前进。

posted @ 2020-09-09 17:10  禅道程序猿  阅读(156)  评论(0编辑  收藏  举报