极限编程 (XP) 和 Scrum 的区别

本贴最后更新于 1560 天前,其中的信息可能已经时移世异

极限编程和 Scrum 都是基于敏捷宣言和 12 原则所创立的软件开发流程框架,其背后的哲学思想都是相同的,XP 和 Scrum 分别按照这个思想设计了流程,因此有很多相似的地方,实属“同父同母的亲兄弟”。

但是再相似的兄弟也会有细节上的区别。

网上关于 XP 和 Scrum 的区别,大多来自于一篇 Differences Between Scrum and Extreme Programming 的文章,但是似乎对这篇文章的质疑也有不少。本文中博主只发表一些自己的看法。

  1. XP 是由多种具体实践组合而成的实践集合,而 Scrum 并没有类似可选内容,是一个相对独立框架。打个不太恰当的比方,XP 就像 python 中的 django,各种组件配套齐全,自由选用,而 Scrum 就像 flask,讲究小而精简。当然 XP 实践库中的内容,比如结对编程和 10 分钟构建,也可以应用在 Scrum 中。

  2. XP 强调了持续集成,Scrum 没有明确要求。XP 中,持续集成背后还意味着测试驱动和自动化构建,需要足够的基础设施支持。Scrum 理论并没有这样的要求,当然实际工作中应该还是会做的。

  3. XP 原则上没有规定团队角色,而 Scrum 明确了团队角色。在极限编程中,并没有强制规定角色,而只是列出了常见的角色,包括 Client、Developer、Tracker 和 Trainer。相对的,在 Scrum 中明确需要存在的角色有 Product Owner、Developer 和 Scrum Master。从职责角度来看,大致可以这样对应:Client 对应 Product Owner,Tracker 和 Trainer 对应 Scrum Master,Developer 对应 Developer。

  4. XP 中规定了 Quarterly Cycle 和 Weekly Cycle,而 Scrum 中的时间周期只有 Sprint。从时间跨度上来说,一个 Sprint 大约 2 到 4 周,介于 Weekly Cycle 和 Quarterly Cycle 之间。

  5. XP 要求全部团队成员要工作在同一个开放的空间中,而 Scrum 并没有这种限制。虽然 XP 和 Scrum 都强调沟通交流,但 XP 就非常明确地指出团队要在同一个空间中工作,而 Scrum 并没有。

总体来说,XP 是一个更完整、更重量级的开发流程框架,它对开发中多种细节都做了规定。相反,Scrum 的强制性规定就相对较少。相对来说,Scrum 是一个更符合自组织特性的框架,以尽量少的规则来组织整个团队的开发。然而,Scrum 中没有明确指出的规则和实践,在实际工作中都是需要做的(比如自动构建、代码规范和重构),这对开发人员自身的素质要求就会更高。而 XP 这种充满“学院派”气质框架,则更加严谨与明确,适合大型项目的管理。

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • Ahian

    昨天去 Thoughtworks 体验了一下午 XP,收获很大

  • 其他回帖
  • someone
    作者

    羡慕羡慕,Thoughtworks 是我理想中的公司

推荐标签 标签

  • 以太坊

    以太坊(Ethereum)并不是一个机构,而是一款能够在区块链上实现智能合约、开源的底层系统。以太坊是一个平台和一种编程语言 Solidity,使开发人员能够建立和发布下一代去中心化应用。 以太坊可以用来编程、分散、担保和交易任何事物:投票、域名、金融交易所、众筹、公司管理、合同和知识产权等等。

    34 引用 • 367 回帖 • 2 关注
  • Sillot

    Sillot (汐洛)孵化自思源笔记,致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点
    Github 地址:https://github.com/Hi-Windom/Sillot

    12 引用 • 26 关注
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    27 引用 • 66 回帖 • 1 关注
  • 阿里巴巴

    阿里巴巴网络技术有限公司(简称:阿里巴巴集团)是以曾担任英语教师的马云为首的 18 人,于 1999 年在中国杭州创立,他们相信互联网能够创造公平的竞争环境,让小企业通过创新与科技扩展业务,并在参与国内或全球市场竞争时处于更有利的位置。

    43 引用 • 221 回帖 • 254 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    51 引用 • 37 回帖
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖 • 1 关注
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    673 引用 • 535 回帖
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 2 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    90 引用 • 383 回帖
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    238 引用 • 224 回帖 • 1 关注
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 105 关注
  • abitmean

    有点意思就行了

    14 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    393 引用 • 3380 回帖
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    20 引用 • 245 回帖 • 232 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 457 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 21 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    70 引用 • 532 回帖 • 706 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    164 引用 • 406 回帖 • 523 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    51 引用 • 190 回帖 • 1 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3165 引用 • 8206 回帖
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 637 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 594 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 7 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 66 关注
  • V2Ray
    1 引用 • 15 回帖