什么是敏捷开发?

2年前博客7161
什么是敏捷开发? sqzr316 于2022-06-10 20:02:04发布 8901 收藏 25 分类专栏: practice 文章标签: scrum 敏捷开发 java practice 专栏收录该内容 5 篇文章 1 订阅 订阅专栏 什么是敏捷开发? 敏捷开发是一种以人为核心,迭代,循序渐进的开发方式。在敏捷开发中,软件项目的构建被切分成多个子项目,各个子项目的成果都经过测试,具备集成和可运行的特征。加单的说,敏捷开发并不是追求前期完美的设计、完美编码,而是力求在很短的周期内开发出产品核心功能,尽早发布出可用的版本。然后在后续的生产周期内,按照新需求不断迭代升级,完善产品。 敏捷开发模式的分类

敏捷开发的实现主要包括Scrum与XP(极限编程,ExtremeProgramming),还有其他的一些方式。

(Scrum:橄榄球的并列争球,橄榄球并列争球的全体前锋,相互拥挤的人群)

Scrum是迭代式增量软件开发过程。

同样是敏捷开发,XP极限编程更侧重于实践,并力求把实践做到极限,实践可以是测试先行,也可以是结对变成,关键要看具体的应用场景。

SCRUM则是一种开发流程框架,也可以说是一种套路。SCRUM框架中包含了三个角色,三个工件,四个仪式。其目的是为了有效完成每一次迭代周期的工作。SCRUM是一个重点。

什么是SCRUM?

SCRUM是一个适用于增量式产品开发的管理框架,由一个5-10人左右的跨职能和自组织的团队组成。

它提供了一个包含角色、规则和工件的结构。团队负责在此框架范围内创建和调整他们的流程。

几个基本术语:

冲刺周期(Sprint)

中文译为冲刺、短跑,是Scrum的专有术语。冲刺周期,通俗的讲就是实现一个“小目标”的周期。一般需要2-6周时间。

用户故事(User Story)

用户的外在业务需求。拿银行系统来举例的话,一个Story可以是用户的存款行为,或者是查询余额等等。也就是所谓的小目标本身。

开发任务(Task)

由故事拆分成的具体开发任务。

三大角色

产品负责人(Product Owner)

主要负责确定产品的功能和达到要求的标准,制定软件的发布日期和交付的内容,同时有权利接收或拒绝开发团队的工作成功。

流程管理员(Scrum Master)

主要负责整个Scrum流程再项目中的顺利实施和进行,以及清除挡在客户和开发工作之间的沟通障碍,使得客户可以直接驱动开发。

开发团队(Scrum Team)

主要负责软件产品在Scrum规定流程下进行开发工作,人数控制在5-10人左右,每个成员可能负责不同的技术方面,但要求每个成员必须要有很强的自我管理能力。同时具有一定的表达能力;成员可以采用任何工作方式,只要能达到Sprint的目标。

三个工件

产品需求列表(Product Backlog):产品首先将需求按照优先级进行排列,产生一个Product Backlog。作用类似于传统开发中项目经理确定需求文档。产品待办列表就是产品的“what”。PO(产品负责人)通过讲故事的方式,让团队理解产品的目标,帮助整个团队对用户故事有充分和统一的理解。

迭代需求列表(Sprint Backlog):有了Product Backlog,我们需要通过Sprint Planning Meeting(Sprint计划会议)挑选出用户故事(Story)作为每次迭代完成的目标。

冲刺燃尽图(Sprint burn down):它表示的是剩余工作量与剩余时间的关系,用于提醒大家项目进度和要完成的任务。说白了就是记录当前周期的需求完成情况。

四个仪式

Sprint计划会(Sprint Planning Meeting):在每个Sprint开始时召开,由全体人员参加。这个会议主要有两件事情要确定。①确定当前Sprint的目标 ②选定当前Sprint要处理的最具价值的用户故事,创建Sprint Backlog(需求列表)

每日站会(Daily Scrum Meeting):一般在15分钟以内。团队成员相互交流任务的进展,计划以及遇到的困难。

Sprint评审会(Sprint Review Meeting):又叫Sprint演示会、Sprint展示会等,是团队用来展示当前Sprint开发成果的会议。

Sprint回顾会(Sprint Retrospective Meeting):用来回顾在当前结束的Sprint中的工作、进行经验总结、反思,并拟定响应的改进措施。

5个价值观 承诺专注开放 Scrum中一切信息对所有人开放,让问题无所隐藏尊重勇气 Scrum开发流程

1.我们首先需要确定一个产品需求列表(Product Backlog),这个是由PO负责的。

2.有了Product Backlog,我们需要通过Sprint Planning Meeting(Sprint计划会议)来从中挑选出一个Story作为本次迭代完成的目标。

3.Sprint Backlog是由Scrum Team完成的,每个成员根据Sprint Backlog再细化成更小的任务(每个任务的工作量可以在2天内完成)。

4.进行Daily Scrum Meeting(每日站会),每次会议控制在10分钟以内,每个人都必须发言,并且要向所在组成员当面汇报你昨天完成了什么,并且向所有组成员承诺你今天要完成什么,同时遇到不能解决的问题也可以提出,相关人员在会后进行解答、处理。

5.当一个Story完成,也就是Sprint Backlog被完成,也就表示一次Sprint完成,这时,我们要进行Sprint Review Meeting(演示会议),也称为评审会议,产品负责人和客户都要参加(最好本公司老板也参加),每一个Scrum Team的成员都要向他们演示自己完成的软件产品。

6.最后就是Sprint Retrospective Meeting(回顾会议),也称为总结会议,以轮流发言式进行,每个人都要发言,总结讨论改进的地方,放入下一轮Sprint的产品需求中。

总结:1、确定产品需求列表-2、Sprint计划会议-3、Strum Team开始分工Sprint-4、Daily Strum Meeting每日站会-5、Sprint Review Meeting,Sprint的评审会议,演示会议-6、Sprint Retrospective Meeting,Sprint的总结会议。

敏捷开发和瀑布式开发比较

工作方式:

瀑布式开发:①重视和强调过程文档,以文档驱动项目,将软件项目开发周期严格划分为几个固定阶段(需求分析,系统设计,软件设计,编码,测试,交付),每个阶段结束都有对应的详细文档作为输出;②上一个阶段的输出就是下一个阶段的输入,直至完成整个开发流程。

敏捷开发:①更加强调人和协作(团队之间,客户与团队之间),在高度协作的环境中使用迭代方式进行增量开发。②客户可对每次迭代的成果提出修改意见,开发人员进行调整和完善。③进行多次迭代直至完成完整产品交付。

优点:

瀑布式:

①每个阶段目的明确,阶段人员完全专注于该阶段的工作,有助于提高阶段效率。②由于存在详细的过程文档,在早期就能明确提出项目的范围和概况,能够更有效的组织和调配资源开展项目。

敏捷开发:

①阶段性成果可以在开发过程中被客户查验,从而降低软件开发风险性。

②灵活性高,需求的变更可在任何时候进行。

缺点:

瀑布式开发:

①开发过程中大量的文档,极大的增加了工作量。②项目后期才能展示成果给客户,增加了项目开发的风险。③需求变更成本高。

敏捷开发:

①最终交付的内容无法预测,预期和实际完成的内容经常会有很大差异。②敏捷需要高水平的协作以及开发人员和用户之间的定期沟通。业务和IT人员在沟通前需要做大量的准备工作,在很多情况下,业务的沟通时间无法保证。

适用项目:

瀑布式开发:

软件需求十分明确并且不会有频繁变化的项目

敏捷开发:

需求不明确、具有创新性或者需要抢占市场的项目。

总结

​ 很显然,敏捷开发与瀑布式开发有着质的区别,但总的来说,在管理项目过程中,都不会严格的按照完全的敏捷开发或者完全的瀑布开发,而是各自参杂了其他的方式。

​ 可见,项目管理过程中,过于强调模式并没有意义,重要的是要能预防问题的发生,在问题发生之后,能用最小的成本解决,模式起到的更多是一个参考作用。

相关文章

[ vulhub漏洞复现篇 ] Django SQL注入漏洞复现 CVE-2021-35042

[ vulhub漏洞复现篇 ] Django SQL注入漏洞复现 CVE-2021-35042...

前端的ajax你知多少?ajax完全指南奉上

前端的ajax你知多少?ajax完全指南奉上...

Ubuntu 20.04 虚拟机安装教程

Ubuntu 20.04 虚拟机安装教程...

YOLO 超详细入门(含开源代码)——网络结构、细节、目标损失函数、优点

YOLO 超详细入门(含开源代码)——网络结构、细节、目标损失函数、优点...

全面认识二极管,一篇文章就够了

全面认识二极管,一篇文章就够了...

【数据库迁移系列】使用pg_chameleon将数据从MySQL迁移至openGauss数据库

【数据库迁移系列】使用pg_chameleon将数据从MySQL迁移至openGauss数据库...