敏捷开发方法:程序员
敏捷软件开发又称敏捷开发,是一种从1990年代开始逐渐引发普遍关注的一些新型软件开发方法,是一种应对快速变化的需求的一种软件开发能力。它们的具体名称、理念、过程、术语都不尽相同,相对于“非敏捷”,更强调程序员团队与业务专家之间的紧密协做、面对面的沟通(认为比书面的文档更有效)、频繁交付新的软件版本、紧凑而自我组织型的团队、可以很好地适应需求变化的代码编写和团队组织方法,也更注重软件开发中人的做用。编程
敏捷方法有时候被误认为是无计划性和纪律性的方法,实际上更确切的说法是敏捷方法强调适应性而非预见性。安全
适应性的方法集中在快速适应现实的变化。当项目的需求起了变化,团队应该迅速适应。这个团队可能很难确切描述将来将会如何变化.测试
相比迭代式开发二者都强调在较短的开发周期提交软件,敏捷方法的周期可能更短,而且更增强调队伍中的高度协做。编码
二者没有不少的共同点,瀑布模型式是最典型的预见性的方法,严格遵循预先计划的需求、分析、设计、编码、测试的步骤顺序进行。步骤成果做为衡量进度的方法,例如需求规格,设计文档,测试计划和代码审阅等等。spa
瀑布式的主要的问题是它的严格分级致使的自由度下降,项目早期即做出承诺致使对后期需求的变化难以调整,代价高昂。瀑布式方法在需求不明而且在项目进行过程当中可能变化的状况下基本是不可行的。设计
相对来说,敏捷方法则在几周或者几个月的时间内完成相对较小的功能,强调的是能将尽早将尽可能小的可用的功能交付使用,并在整个项目周期中持续改善和加强。资源
有人可能在这样小规模的范围内的每次迭代中使用瀑布式方法,另外的人可能将选择各类工做并行进行,例如极限编程。开发
在敏捷方法其独特之处之外,他和其余的方法也有不少共同之处,好比迭代开发,关注互动沟通,减小中介过程的无谓资源消耗。一般能够在如下方面衡量敏捷方法的适用性:从产品角度看,敏捷方法适用于需求萌动而且快速改变的状况,如系统有比较高的关键性、可靠性、安全性方面的要求,则可能不彻底适合;从组织结构的角度看,组织结构的文化、人员、沟通则决定了敏捷方法是否适用。跟这些相关联的关键成功因素有:文档
最重要的因素恐怕是项目的规模。规模增加,面对面的沟通就越发困难,所以敏捷方法更适用于较小的队伍,40、30、20、10人或者更少。大规模的敏捷软件开发尚处于积极研究的领域。
另外的问题是项目初期的大量假定或者快速收集需求可能致使项目走入误区,特别是客户对其自身须要毫无概念的状况下。与之相似,人之天性很容易形成某我的成为主导并将项目目标和设计引入错误方向的境况。开发者常常能把不恰当的方案授予客户,而且直到最后发现问题前都能得到客户认同。虽然理论上快速交互的过程能够限制这些错误的发生,但前提是要有效的“负反馈”,不然错误会迅速膨胀,并在最终提交时形成极大返工。