敏捷宣言和准则

简介:

敏捷宣言和准则

1.敏捷宣言起源
在2001年,17位敏捷方法论的拥护者和倡议者聚集在犹他州的雪鸟滑雪场,起草了一份陈述敏捷组织原则的文件。
这份文件基本上代表了不同敏捷方法论的共同点。当你读到这个宣言,你会发现它具有最高原则性,因为敏捷方法论在最高层面上是一致的,但到具体细节上每种方法都会不同。

2.敏捷宣言
我们一直在实践中探寻更好的软件开发方法,身体力行的同时也帮助他人。由此我们建立了如下价值观:
个体和互动 高于 流程和工具;
工作的软件 高于 详尽的文档;
客户合作 高于 合同谈判;
响应变化 高于 遵循计划;
也就是说,尽管右项有价值,我们更重视左项的价值。

3.敏捷宣言价值观
(1).个体和互动高于流程和工具
项目是通过人来完成的,流程和工具可以帮助人,但绝不能自行完成工作。虽然,过程和工具都是好东西,但是它们有时也会成为障碍。面对面的直接沟通,比一些流程性的文件和工具沟通,效率要高出很多。当然最好的是,在沟通后就多方达成的共识形成一个简要性的文档备录。
(2).工作的软件高于详尽的文档
可用软件的价值是很重要的,因为软件是为业务目标提供支持的,是可用软件(而不是文件)为客户和也会传递了高价值。一般来说,一个敏捷项目的进展情况是由开发了多少可用软件来跟踪和报告的。但不是说文档一无是处,适量的文档在绝大多数的项目中是有益的和必要的。敏捷通过寻求“刚好足够”的文档来避免这种情况。其中的原则是任何文件的创建都应与为客户创造的价值直接挂钩,且不论该价值体现在现状还是将来。
(3).客户合作高于合同谈判
这对价值观的核心是越接近你的客户越好。客户最清楚他想要什么,即使在需求明确过程中也会包含一些试验和错误。在合同谈判期间,试图避免所有的尝试和错误不发生是不现实的,也是徒劳的。定位你与客户的关系很重要,你是选择对抗你的客户还是选择与你的客户一起为接近方案努力而使每个人都受益?敏捷团队更愿意和客户在同一方向一起使劲而不是把力气花在背离客户的方向。
(4).响应变化高于遵循计划
任何一个曾在软件项目工作过的人都知道这些项目的本质就是变化。即使底层的技术也在快速变化,新的途径和可能性在不断的被打开。对变化响应的速度就决定你在市场上的灵活性,循规蹈矩的做事将被市场甩在后面,永远慢市场半拍,慢慢你的市场会被蚕食掉。

4.敏捷准则
除了敏捷宣言之外,还有12条准则的支持文件,为敏捷宣言提供了更多的扩充细节。
(1).准则1 我们的最高目标是,通过尽早和持续地交付有价值的软件来满足客户
敏捷团队可以很快将可用软件交付到客户手中,并且是开放式地快速更新,给客户带来优先级最高地价值。
(2).准则2 欢迎对需求提出变更,即使在项目开发后期;要善于利用需求变更,帮助客户获得竞争优势
传统项目管理中地一个原则是设法去影响和控制会导致变化地因素。敏捷项目管理预期到需求会发生变化,并在实际过程中欢迎拥抱这些变化,即使这些变化发生在项目后期。迅速应对和适应变化能给客户带来显著地竞争优势,从而应对新的机遇。
(3).准则3 要不断交付可用的软件,周期从几周到几个月不等,且越短越好
不同的敏捷方法论采用不同的迭代周期,但都是相对较短的。关键是能快速把可用的软件交付到客户手上并能利用软件获得有意义的回报。较短的迭代周期为团队提供架构并强化团队持续关注客户的价值。
(4).准则4 在项目过程中,业务人员与开发人员必须在一起
敏捷项目管理,让业务人员和开发人员彼此靠近,并时常让他们在同一个地方一起工作,通过这样的方式让业务人员和开发人员之间没有隔阂。是因为业务人员和开发人员的共同目标就是通过可用的软件向客户传递价值。
(5).准则5 要善于激励项目人员,给他们所需要的环境和支持,并相信他们能够完成任务
传统项目管理,常对员工进行微观管理,不仅告诉他们要做什么,还告诉他们如何做,无意间形成自上而下的管理方式。敏捷项目建立了一支强有力的团队并积极避免微观管理,要求一个自律的团队,自发告知开发人员做什么。提供相关资源,给予鼓励,相信团队能够完成任务。
(6).准则6 无论是团队内还是团队间,最有效的沟通方法是面对面的交谈
非正式口头的沟通在敏捷项目管理中远比正式的书面沟通更普遍。其想法是两个人坐在一起为一个解决方案努力会比他们用邮件来来往往或交换文件更有效率。面对面沟通是敏捷项目管理的精髓。这种沟通是公开的,任何团队成员都可以自由参与对话。
(7).准则7 可用的软件是衡量进度的主要指标
计划和文件可能是有用的,但是当最根本的目标发生变化时,它们就可能失去应有的价值。传统项目往往极其纠结的是,项目的不断更新使得文件成为一种负担。真正的价值是通过结果来表达的,结果又是通过可用的软件来呈现的。
(8).准则8 敏捷过程提倡可持续的开发。项目方、开发人员和用户应该能够保持恒久稳定的进展速度
可持续开发的焦点是在团队身上,他们会努力保持一个稳定的可持续的进展速度,从而使得团队成员不会在迭代周期的尾端匆忙赶工。理想的目标是保持一种可持续的速度,使团队成员不会感到过度的压力和筋疲力尽,而是能够保持在一个理想的强度下工作。
(9).准则9 对技术的精益求精及对设计的不断完善将提升敏捷性
设计的越完善,维护起来就越简单,即使遇到变化。稳定和优质的项目会比劣质的项目更加允许团队快速应对变化。
(10).准则10 要做到简洁,即尽最大可能减少不必要的工作。这是一门艺术。
这个被所有的敏捷方法所拥护,尤其使精益方法。关键点对客户价值保持关注和毫无犹豫的削减不增加价值的活动。保持简单不只是一种愿望,它使最基本的原则。
(11).准则11 最佳的架构、需求和设计出自自我组织的团队
自我组织是敏捷团队的核心元素之一。当一个团队是自我组织型的时候,说明该团队自己去决定工作如何分配及谁去做某个特定的工作,而不是人力资源部门或管理层来决定。不仅小团队是自我组织的,较大的跨职能团队也可以是自我组织的。
(12).准则12 团队要定期反省如何能够做到更有效,并相应的调整团队的行为
敏捷项目中最可预见的事情就是变更。传统项目里当项目或阶段完成时开会总结是最常见的做法。而敏捷试着通过更频繁的回顾来完成这项工作。在一个回顾活动中,团队查看各迭代周期中已完成的工作或发布,并评估下一次如何改进他们的做法。每日站立会议即每天简单碰头15分钟是另一项协调团队努力方向、团队自我评定和自我调整的重要方式。


5.现代管理相互依赖声明

现代管理相互依赖声明是由阿利斯特尔*科克巴姆和吉姆*海史密斯为主的一群人在2005年撰写的。
(1).通过持续为客户创造价值来提高投资回报;
(2).通过不断的与客户交互,共享所有权利来交付可靠的结果;
(3).预测不确定性,并设法通过迭代、预测、适应来应对不确定性;
(4).个体价值是团队价值的源泉,要创建能让个体卓越的环境,实现创造和创新;
(5).通过激发成员的使命感和责任感来提高团队绩效;
(6).通过使用根据具体情况而定的策略、流程和做法来提高效率和可靠性;


本文转自SanMaoSpace博客园博客,原文链接:http://www.cnblogs.com/SanMaoSpace/p/6283904.html,如需转载请自行联系原作者

相关文章
|
4月前
|
敏捷开发 监控 测试技术
敏捷软件质量保证的方法与实践
本文介绍了软件质量保证(SQA)的重要性及其在敏捷开发中的实践方法。文章首先指出了传统测试方法的问题,如成本高昂和项目风险加大。为解决这些问题,文中提出了需求审核、代码审核与演练、基于会议的测试及基于风险的测试等多种实践方法。此外,文章还探讨了衡量软件质量的常见指标,如源代码行数、代码段/模块/时间段内的Bug数和代码覆盖率等。文中还详细描述了敏捷开发过程中QA的角色与活动,强调了QA需与开发人员、业务人员及客户密切协作,以确保产品质量。最后,文章指出了在敏捷开发中QA的特殊性及其对团队构成、测试阶段、工作方式等方面的影响。
102 3
敏捷软件质量保证的方法与实践
|
4月前
|
测试技术 UED 开发者
《敏捷测试价值观、方法与价值观》读书笔记(9)
本章节聚焦于非功能性测试,尤其深入探讨了可用性测试的重要性和实施方法。首先,阐述了可用性原则如简洁设计、一致性及高效性等,并强调用户而非开发者才是评判应用易用性的关键。接着介绍了可用性测试的不同技术和环境需求,包括卡片分类、结构化评估等方法,并讨论了测试实验室的具体配置。此外,详细说明了测试过程中的计划、执行、分析阶段,涵盖了从测试目标设定到测试结果优化的全流程。同时,还提供了测试参与者招募标准、测试材料准备及执行过程中注意事项的具体示例。最后,指导如何整合与分类测试结果,以及生成可用性测试报告的方法。
28 0
|
7月前
交付成果 提高IT领导力的七大窍门
交付成果 提高IT领导力的七大窍门
|
7月前
|
敏捷开发 开发者
拥抱不确定性:软件开发中的敏捷思维
【5月更文挑战第37天】 在快速变化的技术世界中,不确定性已成为常态。本文探讨了如何通过敏捷思维来拥抱这种不确定性,提高软件开发的适应性和效率。通过分析敏捷方法论的核心原则,我们将了解如何在项目开发过程中灵活应对变化,优化团队协作,并持续改进产品。文章将强调在不确定性环境中,敏捷思维如何转化为竞争优势,以及如何在日常工作中实践这一思维方式。
|
存储 分布式计算 架构师
【企业架构】敏捷时代的企业架构:更少的监管,更多的指导
【企业架构】敏捷时代的企业架构:更少的监管,更多的指导
|
敏捷开发 架构师
「敏捷开发」企业架构和敏捷开发:对立吸引?
「敏捷开发」企业架构和敏捷开发:对立吸引?
|
存储 开发者
软件研发中的N条原则
软件研发中的N条原则
224 0
软件研发中的N条原则