`

《敏捷迭代开发管理者指南》读书笔记

阅读更多

这是一本关于迭代开发的各个流派的一个总结式读本. 可以让你在最短的时间内了解各个敏捷开发方式是如何实现迭代开发的.

==============我是读书笔记的分割线===================
拒绝固定需求文档的理由:
客户或用户不能明确知道他们要什么
他们很难陈述他们的需求和知识
他们想要的许多细节只能在开发过程中逐步展现
细节对于他们来说过于复杂
当他们看到产品的开发, 会改变他们的初衷
外部的(竞争)压力导致需求的变更或者增强

敏捷需求:从我们的已经产生的高级需求列表中, 挑选出20%最具有架构意义, 最具有风险以及最具有价值的条目

由于存在比较高的变化率, 这成为敏捷与迭代开发的动机的核心

短小的迭代导致对完成, 能力与结束有一种快捷和反复的感觉. 这些心理学因素对于个体成就感和构建团队信心至关重要, 这同样也构建了团队中客户信心--他们看到早期的可视化的过程, 朝着他们关心的方向发展.

研究表明在提高生产率方面, 时间箱带来好处的一个原因就是专注.

心理学认为结束日期为三周之后, 比在三个月之后设立的可视里程碑, 专注的效果更好

通过在为期两周的时间箱迭代, 团队可承担可管理的复杂度, 做他们力所能及的工作, 同时也可以在可能突破最后期限内的情形下, 他们有能力缩小工作范围.

瀑布型的方法只适应于非常直接, 缺少变化的项目.

瀑布模型的开发方式, 将高风险和困难的元素推迟到项目最后, 而对于迭代开发方式来说, 则是通过风险驱动的迭代, 使最困难和最具风险的元素尽早地出现并解决.

scrum的一个关键理念是强调经验型过程, 而不是规定性的过程.

系统开发有着非常巨大的不确定性和复杂性. 以至于它必须通过经验型的过程控制模式来管理.

晨会的第三个问题: 是什么阻碍了目标的实现?

增加的两个问题:
有没有任务添加到Sprint待办事宜中?
相对于团队中的其他成员, 你是否学到了一些东西或者做出了一些新的决定(技术, 需求...)

晨会最好在一块白板前召开, 白板用于开会的记录报告的所有任务和障碍

scrum的价值观:
承诺: 团队承诺实现规定的迭代目标
专注: 团队需要排除干扰, 专注于规定的迭代任务
公开: 公开产品待办事宜, 使工作以及优先级都可以被看到
尊重: 强调整个团队的责任, 而不是寻找替罪羊
勇气: 管理者应该有勇气制定计划并进行相应的指导.

XP
xp的独到之处在于, 除了代码和测试, 它不需要其他详细工件, 但也不排斥其他工件

xp不是黑客式的边写边改, 而是摒弃了大部分的文档开销, 更强调代码生产力和口头沟通.

极限编程中的"极限"表示的是要将软件开发中的优点演绎到极致, 也就是说如果是好的实践, 就应该最大限度的发挥它们的作用.

测试是好的实践, 于是所有代码编写单元测试
代码审查是好的实践, 那么实时的进行代码审查, 并且在整个开发过程中通过结对来进行代码审查.
对所有开发人员的代码进行频繁的集成是一项好的实践, 那么用一台专门的机器, 进行自动, 7*24不停的进行持续集成.
短期迭代是好的实践...
客户更多的参与是好的实践...
沟通是好的实践...

XP鼓励用最简单的方式记录需求

XP故事不是用例或者场景, 它们通常描述特征

XP中口头沟通是首选, 故事卡的目的不在于细化故事, 而是略记一个大概, 作为其他文档的参考, 一般情况下将卡片看成沟通提示.

避免文档可以通过现场客户来进行弥补, 但并不反对文档, 只是将其看成一种开销, 希望通过更多的时间进行编程

编写测试的实践将影响构思, 澄清和简化设计.

TDD使开发者具有成就感: 我编写测试, 然后我取得测试的成功, 这种满足感驱使着实践.

当迭代无法在时间箱内完成, 延长周期是一种错误的认识, 更好的做法是取消这次迭代, 或者简化一些目标, 并分析这次失败的原因是什么.

分享到:
评论

相关推荐

    敏捷流程资料

    敏捷开发流程是一种以人为核心、迭代、循序渐进的开发方法论,它强调灵活性和快速响应变化。在“敏捷流程资料”这个压缩包中,包含了一系列与敏捷开发相关的文档和数据,旨在提供敏捷流程培训及数据分析的支持。 ...

    软件设计师复习笔记资料.rar

    了解瀑布模型、敏捷开发、迭代模型等软件开发流程,掌握UML(统一建模语言)用于系统建模,以及需求分析文档的编写,如需求规格说明书、用例图和活动图等。 二、编程语言与数据结构 编程语言是软件设计师的工具,如...

    项目管理笔记

    - **敏捷项目管理**:强调迭代和灵活应对变化,适用于快速变化的环境,如软件开发。 - **精益项目管理**:旨在消除浪费,提高效率,适用于制造业或流程优化项目。 - **六西格玛**:关注数据驱动的质量改进,减少缺陷...

    项目管理笔记:项目管理学习笔记与经验教训

    敏捷项目管理强调灵活性和迭代开发,如Scrum和Kanban,它们注重快速反馈和持续改进。 5. **经验教训**: - 明确项目目标:清晰的项目目标有助于保持团队共识。 - 有效沟通:定期沟通可以减少误解,提高团队效率...

    系统集成项目管理工程师教材笔记(精华归纳整理).docx

    - **典型的信息系统项目的生命周期模型**:如瀑布模型、迭代模型、敏捷模型等。 - **单个项目的管理过程**:覆盖项目启动到收尾的整个流程。 - **项目管理高级话题**:探讨项目组合管理、项目治理等。 #### 五、...

    信息系统核心学习笔记

    - **敏捷开发**:迭代、灵活地适应变化。 - **螺旋模型**:结合了瀑布模型和原型模型的优点。 - **原型法**:快速构建系统原型供用户测试反馈。 - **面向对象开发**:强调封装、继承、多态等概念。 ##### 4.2 软件...

    UML学习笔记 建模语言

    - **统一过程(UP)**:UP是一种流行的迭代式软件开发过程,强调在开发周期中逐步细化需求和设计。 - **Rational统一过程(RUP)**:作为UP的一个具体实例,RUP提供了更详细的指南和最佳实践,支持软件开发的整个...

    软件工程期末复习指南.docx

    - **迭代模型**:多轮迭代开发,每次迭代产生可运行的产品部分。 - **敏捷模型**:强调灵活性和快速响应变化,适用于需求不明确或易变的项目。 #### 二、需求工程 1. **需求获取**: - 方法:访谈、问卷调查、...

    个人经历的pmp积累.zip

    11. **敏捷方法**:如Scrum、Kanban等,适用于软件开发项目的迭代和灵活响应变化的方式。 12. **软件开发工具**:如Git等版本控制工具,以及Jira、Trello等项目管理工具的使用。 13. **实战案例分析**:具体项目...

    软件设计师复习资料.zip

    理解软件工程的原则和实践,如敏捷开发、迭代模型和瀑布模型,对于软件设计师来说至关重要。 二、需求分析与管理 需求分析是软件设计的第一步,涉及识别、定义和记录用户需求。软件设计师需要掌握如何使用工具如UML...

    2005~2019历年软件设计师真题详解(word+pdf).zip

    考生需要理解软件生命周期模型,如瀑布模型、迭代模型、敏捷开发等,并熟悉软件设计原则和设计模式。 2. **编程语言**:虽然具体语言可能因年份而异,但C、C++、Java、Python等常用语言的基础语法和高级特性是常考...

    考试软件设计师考试软件设计师考试软件设计师

    考试软件设计师需要熟悉各种软件工程方法,如瀑布模型、迭代模型、敏捷开发等。敏捷方法强调快速响应变化,如Scrum和Kanban,这些方法在现代软件开发中广泛应用。 三、系统分析与建模 UML(统一建模语言)是软件...

    软件工程各种文档下载.rar软件工程各种文档下载.rar

    这可能包括软件生命周期模型(如瀑布模型、迭代模型、敏捷开发等)、需求获取与管理、软件设计原则、编程规范、测试策略以及项目管理等内容。通过学习这些文档,开发者可以了解软件开发的整体流程,提高专业素养。 ...

    系统分析师经典教材_word版

    1. **系统分析基础**:介绍系统分析的基本理论,包括系统工程、信息系统的生命周期和系统开发方法论(如瀑布模型、迭代模型、敏捷开发等)。 2. **需求分析**:讲解如何识别和定义用户需求,使用工具如数据流图、...

    CMMI Model V3.0 CMMI模型3.0版本

    - 重视敏捷和精益实践:新版本中,CMMI与敏捷和精益开发方法论更好地融合,以适应快速变化的环境。 - 提升用户体验:模型的表述方式更加清晰,便于理解和应用。 CMMI V3.0还包含了CMMI性能解决方案生态系统(CMMI ...

    项目工作模型数据专员共4页.pdf.zip

    常见的工作模型有瀑布模型、敏捷开发、迭代模型和螺旋模型等,每种模型都有其特定的优势和适用场景。 2. **数据专员**:数据专员是负责收集、整理、分析和维护数据的专业人员。他们的主要任务可能包括数据录入、...

    手慢无!软件架构师精品课程,速度领取

    其次,"如何查看和使用.txt"很可能是指导文件,详细介绍了如何有效利用压缩包中的资料,包括如何阅读和理解学习笔记,以及如何使用思维导图查看器。遵循这些指南,学习者可以避免走弯路,更高效地吸收知识。 最后,...

    学生资料:公开提供学生资料的资料库

    "Agile项目管理"是一种流行的软件开发和项目管理方法,强调迭代和灵活应对变化。因此,资料库可能有相关的教程、案例研究或指导文档,帮助学生和专业人士了解和实践敏捷方法。 "Technical Writing"是指专门用于解释...

    hackathon

    5. **docs** 或 **documentation** 文件夹:项目文档,包括API参考、使用教程、开发笔记等。 6. **LICENSE** 文件:表明项目使用的开源许可协议,如MIT、Apache 2.0等。 7. **README其他语言版本**:如果活动国际化...

Global site tag (gtag.js) - Google Analytics