1软件工程SoftwareEngineering成都信息工程学院成都信息工程学院计算机系计算机系软件工程SoftwareEngineering主讲教师:魏维2软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系第十一章敏捷软件开发与极限编程Outlines敏捷软件开发概述敏捷方法与规范化方法的关系极限编程实践案例3软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系一些经验丰富的软件设计师在应对快速交付、需求易变的开发要求实践中分别总结出自己独特且有效的软件开发方法,被业界概括为敏捷软件开发方法。其中以“极限编程”最为流行。4软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系敏捷软件开发概述敏捷软件开发方法其实不是一个具体的过程,而是一个涵盖性术语。用于概括那些应需而生的具有类似价值观的软件开发方式和方法,这些方法一般都具有以人为核心、循环迭代、响应变化等特点,着眼于能高质量地快速交付客户满意的工作软件。什么是敏捷软件开发方法?5软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系代表性的敏捷开发方法极限编程(eXtremeProgramming,简称XP)特征驱动软件开发(FeatureDrivenDevelopment,简称FDD)动态系统开发(DynamicSystemsDevelopmentMethodology,简称DSDM)自适应软件开发(AdaptiveSoftwareDevelopment,简称ASD)SCRUMCrystal6软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系“敏捷联盟”的价值观个体与交互重于过程与工具可以工作的软件重于面面俱到的文档与客户的合作重于与其合同的谈判对变化的响应重于对计划的遵循可见,敏捷的软件开发方法的理念是,在保证软件开发有成功产出的前提下,尽量减少开发过程中的活动和制品的方法;在满足软件质量要求的前提下,力求适应变化和提高开发效率。7软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系敏捷软件开发的原则1.敏捷开发而言,最重要的是通过尽早和不断交付有价值的软件来满足客户的需求。2.敏捷开发欢迎需求的变化,即使是开发后期。敏捷过程能够驾驭变化并以此为客户创造竞争优势。3.经常交付可以工作的软件,从几个星期到几个月,时间间隔越短越好。4.业务人员和开发人员应该在整个项目过程中始终朝夕在一起工作。5.围绕斗志高昂的人进行软件开发,给他们提供适宜的环境,满足他们的需要,并相信他们能够完成任务。8软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系6.在团队中,最有效率也最有效果的信息表达方式是面对面的交谈。7.可以工作的软件是进度的主要度量标准。8.敏捷过程提倡可持续的开发速度。责任人、开发者和用户应该总是维持不变的节奏。9.对优秀的技能与好的设计的不断追求将有助于提高敏捷能力。10.简单——尽可能减少工作量的艺术是至关重要的。11.最好的架构、需求和设计都源自自组织的团队。12.每隔一定时间,团队都要总结如何更有效率,然后相应地调整自己的行为。敏捷软件开发的原则9软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系典型敏捷方法:极限编程(XP)(XP)XP方法的基础是4个价值观念:沟通。大多数项目的失败源于沟通不畅,所以要进行一些能够推动积极沟通的实践。简单。开发能够满足客户需要的最简单的产品。反馈。开发者必须要获取并且重视来自客户、系统的反馈以及相互之间的反馈。勇气。准备好做出支持其他原则和实践的艰难决定。10软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系XP在4个价值观之上,又定义了12个的必须遵循的实践:1.完整团队:XP项目的所有参与者(开发人员、客户、测试人员等)一起工作在一个开放的场所中,他们是同一个团队的成员。这个场所的墙壁上随意悬挂着大幅的、显著的图表以及其他一些显示他们进度的东西。2.计划游戏:计划是持续的、循序渐进的。每2周,开发人员就为下2周估算候选特性的成本,而客户则根据成本和商务价值来选择要实现的特性。3.客户测试:作为选择每个所期望的特性的一部分,客户可以根据脚本语言来定义出自动验收测试来表明该特性可以工作。典型敏捷方法:极限编程(XP)(XP)11软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系4.简单设计:团队保持设计恰好和当前的系统功能相匹配。它通过了所有的测试,不包含任何重复,表达出了编写者想表达的所有东西,并且包含尽可能少的代码。5.结对编程:所有的产品软件都是由两个程序员、并排坐在一起在同一台机器上构建的。6.测试驱动开发:编写单元测试是一个验证行为,更是一个设计行为。同样,它更是一种编写文档的行为。编写单元测试避免了相当数量的反馈循环,尤其是功功能能验证方面的反馈循环。程序员以非常短的循环周期工作,他们先增加一个失败的测试,然后使之通过。典型敏捷方法:极限编程(XP)(XP)12软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系7.改进设计:随时利用重构方法改进已经腐化的代码,保持代码尽可能的干净、具有表达力。8.持续集成:团队总是使系统完整地被集成。一个人拆入(Checkin)后,其它所有人责任代码集成。9.集体代码所有权:任何结对的程序员都可以在任何时候改进任何代码。没有程序员对任何一个特定的模块或技术单独负责,每个人都可以参与任何其它方面的开发。典型敏捷方法:极限编程(XP)(XP)13软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系10.编码标准:系统中所有的代码看起来就好像是一人单独编写的。11.隐喻:将整个系统联系在一起的全局视图的概念。它是系统的未来影像,是它使得所有单独模块的位置和外观变得明显直观。如果模块的外观与整个隐喻不符,那么你就知道该模块是错误的。12.可持续的速度:团队只有持久才有获胜的希望。他们以能够长期维持的速度努力工作,他们保存精力,把项目看作是马拉松长跑,而不是全速短跑。典型敏捷方法:极限编程(XP)(XP)14软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系15软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系极限编程是一组简单、具体的实践,这些实践结合在形成了一个敏捷开发过程。极限编程是一种优良的、通用的软件开发方法,项目团队可以拿来直接采用,也可以增加一些实践,或者对其中的一些实践进行修改后再采用。典型敏捷方法:极限编程(XP)(XP)16软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系17软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系敏捷方法与规范化方法的关系二者的比较:“敏捷宣言”把关注的焦点从传统的计划驱动、基于过程的方法转移到更轻量、适应性更强的开发范型。但并不意味着可以忽略对传统方法中强过程规范和严格准则的需要,这些软件开发方法为规范软件开发的过程,提高软件项目的成功率起了重要的作用。18软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系如同过于繁琐与官僚化的过程和文档阻碍软件开发一样,过度地强调简单与抛弃文档也会对软件项目造成伤害。纯粹的敏捷开发方法同样要求软件企业组织管理能力和开发人员个人非常高的素质传统的计划驱动方法的擅长领域通常是大型、复杂的系统,这些系统时常具有关键的安全性或者其他高可靠性的属性。需求应该相当稳定,环境也具有相当的可预见性。敏捷方法则更适用于那些系统和开发团队规模较小、客户和系统的使用者随时可以到位、需求和环境容易变化的项目。19软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系平衡敏捷与规范:为了维持相关性并符合客户的需要和期望,国防和其他大型系统必须找到适当的途径在它们的方法学中融合敏捷性。但仍必须把规范作为适应性的基础。典型地,可以将敏捷方法与统一软件开发过程(RUP)等规范方法相结合。比如,RUP作为整体框架,负责最初前景分析、商业计划,敏捷建模负责业务建模,具体开发使用XP等敏捷方法。而在整个项目的项目管理、配置管理、质量管理使用RUP。进一步可将SW-CMM作为整个过程改进的目标,根据CMM五级目标可以制定与过程改进相符的阶段目标和长远目标。20软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系极限编程实践细则极限编程的12个核心实践具体分来有如下四个方面一些细则内容:1.计划①写出用户素材;②根据发布版本计划编制进度表;③频繁发布小版本:④度量项目速度;⑤这个项目划分为多个迭代;⑥每次迭代开始前制定迭代计划;⑦角色互换;⑧每日立式晨会;⑨根据项目情况对XP作出调整。21软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系2.设计①简单;②选取一个系统比喻;③在设计会上使用CRC卡片;④通过探针方案降低风险;⑤不要过早加入任何功能;⑥尽可能的进行重构。极限编程实践细则22软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系3.编码①客户一直在场;②代码必须符合相应的编码标准;③首先编写单元测试;④必须实行结对编程;⑤严格的串行代码集成;⑥频繁地进行代码集成;⑦实行代码共有制;⑧将优化工作留到最后;⑨不要加班。极限编程实践细则23软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系4.测试①所有代码必须有单元测试;②所有代码发布前必须100%通过所有对应的单元测试;③发现了错误必须要增加相应的测试;④经常运行接受测试并且公布其结果。极限编程实践细则24软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系25软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系软件开发过程中会遇到那些问题?26软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系疲于应付变化的需求质量不尽如人意无法按时交付……27软件工程SoftwareEngineering——第十一章敏捷软件开发与极限编程成都信息工程学院成都信息工程学院计算机系计算机系疲于应付需求变化