敏捷软件开发原则及核心观点
随着项目的不断庞大,对项目进行维护必然会对项目引入新的内容。从而使软件项目不断庞大。另一方面,需求的变化也将引起软件规模的迅速增加。《敏捷软件开发》附录C中第一个Rufus公司项目的例子,正是由于追求一次性庞大完成的输入、设计从而导致项目的失败。为此,敏捷软件开发提出了如本文引用中所提到的4条宣言,它体现了4个核心观点,这4个核心观点又引出了敏捷软件开发的12条原则。
软件的核心观点释义
敏捷软件开发过程中强调人的重要性。敏捷软件开发,再好的过程和工具也必须是由软件开发团队进行使用。如果仅有良好的管理过程,团队成员之间却缺少交流,那么开发的项目将会失败率很高。同时,如果仅有良好的开发工具,而团队成员不具备必要的开发技术,紧依靠工具进行完成,那么软件将会变得很松散。另一方面,敏捷软件开发还强调,一个好的团队不一定是一个技术精湛的团队。一个沟通良好,成员技术水平一般的团队,要比一个由技术精湛的成员组成,但缺少交流的团队的水平高得多。
敏捷软件开发强调文档要少而精。轻量级的软件开发致力于减少各方面的不要支出。文档方面的减少也将给开发工作带来极大的便利。相反,复杂的文档必然会给软件开发带来复杂度高的技术及软件结构。从而违背敏捷软件开发轻量级的意图。
敏捷软件开发强调及时的与客户沟通。及时的与客户沟通,给顾客展示新产品的功能,让顾客提出建议或意见。这样可以满足客户的需求,又可控制软件开发的方向。那种与顾客签订合同,然后闭门造车,软件基本完成时去交付给客户的做法往往会导致产品并非顾客真正的意图,或者不能满足客户新的需求,从而带来客户的不满,导致项目失败。
敏捷软件开发强调及时响应变化。由于是轻量级的开发,基本上每两三周便可交付一个新功能的产品,开发周期较短,从而可以及时响应技术和客户需求带来的变化,降低软件开发过程中的风险。
敏捷软件开发的12条实践原则
由敏捷软件的4条核心价值引出了软件开发的12条原则,它们是:“简单设计、测试驱动、代码重构、持续集成、结对编程、现场客户、发行版本最小化、系统隐喻、代码集体所有、规划策略、规范代码、40小时机制。”