雪鸟会议

雪鸟会议前夕,James Grenning 在 Object Mentor 与 Robert C. Martin 一同工作,彼时组织雪鸟会议的 Bob 大叔盛情邀请 James,告知他会议的地点。James 听到地点后毫不犹豫地答应,并在脑海中踊跃欢呼“我要去滑雪!”毕竟,“雪鸟是世界上最好的滑雪场之一”,没有人会拒绝雪鸟的诱惑。当然,除了滑雪这个最直观的念头,James 也曾与 Kent Beck、Ron Jeffries、Martin Fowler、Ward Cunningham 共事、合作,有这样的机会同这些人一起聊聊关于软件开发的事,这也是另一个非常吸引他的原因。

不过他对参加雪鸟会议是否会对自己的工作产生有利影响没有丝毫期待,在会议现场也只是进行些小组交流,他从未预料到这会对软件开发行业产生如此巨大而深远的影响。“我们很确定没有人会在乎,但至少我们做了一些事情: 找出我们有什么共同点,以及共同点在哪里。”

估算扑克

在一定程度上,《敏捷宣言》是在大家聚在一起找出分歧,再找到共同点的过程中产生的。James 认为,这与估算扑克相似,二者的共同点是: 一个团队需要在哪一部分达成共识。

估算扑克的灵感来源于 James 作为敏捷教练参加的一次失败的计划会议。那一次,团队八个人围坐在桌子旁,两位高级工程师主持此次会议,在会议中,二人不断反复讨论如何构建用户故事。当时在场的 James 极为混乱,他用了半小时甚至一小时的时间才意识到,他们在会议开始时谈论的工时数与在会议结束时谈论的工时数完全一致,整个会议所做的事情只是在争论用什么方法去做。而此时其他参会的六个人都已经昏昏欲睡,这是因为争论的这二人“垄断”了整场会议谈话,而没有参与讨论、估算的人已经近乎脱离会议了。当时的 James 手上正好有索引卡片,于是在这场会议中场休息结束后,他给每个人都发了卡片,并要求提出某项工作后,所有人只能出牌,不能讲话,来达成一致同意。

James 在 Object Mentor 网站上写下了这个故事,提出估算扑克。随后,Mike Cohn 发现了这一方法,并根据自己的经验对估算扑克的设计 进行了完善和增强,同时决定将估算扑克在大范围内推广使用。发布后,这副特殊的扑克在程序员中广受欢迎。

当然,估算并不只依赖于这一副扑克牌,James 自己在被 Lowell Lindstrom 展示过亲和图优先级估算的想法后,已经多年未使用估算扑克。但估算扑克确实能通过以牌面朝下的方式隐藏数字,让团队避免“锚定”的认知偏差,提高估算效率。这是一种既能起到群策群力效果又有效避免众口难调造成混乱的好方法,所以 James 的客户们应用推广,由此产生了 风险扑克、 价值扑克等类型。虽然这两种扑克并未推向市场,但团队想要借鉴的话,实现起来并不困难。

测试驱动开发

1999年,James 开始学习极限编程,从事嵌入式咨询工作。当时一直在为客户编写用例并搭建体系架构的 James 在 Object Mentor 进行了第一次极限编程沉浸式学习,也开始接触一些此前未了解过的事。当他看到当时名为“测试优先于开发”(现在的测试驱动开发)的演示时,他发出惊叹:“哇!我们可以打破对我们没有的东西的依赖。”因此,如果需要构建某个系统,并且处于无法与硬件交互的情况下,仍然可以创建软件,并 通过存根和模拟对象等来开发尚不存在的事物。

激动兴奋之余,受到启发的他产生了为做嵌入式开发的程序员介绍测试驱动开发的念头,也将敏捷介绍给嵌入式开发的群体。他开始在嵌入式系统会议上做关于将敏捷应用于嵌入式软件的演讲。也有了专门写作测试驱动开发的主题的书的念头,这个念头后来成型,就是《测试驱动的嵌入式 C 语言开发》。

从这颗被点燃的火花开始,再到他把敏捷、测试驱动开发的火花带给更多的嵌入式开发工程师,他意识到语言通常是不同的,不仅仅是编程语言,人们相互交流的方式本质上是不同的,因为他们谈论的是不同的东西。不同的整体拥有不同的世界,所以游走于不同的群体间就可以学到不同群体的知识,比如他通过与 Bob 的合作了解到了许多非嵌入式的知识。从面向对象、极限编程到测试驱动开发,他愿意把这些不同世界的知识带给其他世界的程序员。

敏捷本身不是目标,而是寻找诚实而高效的方法来交付有价值的产品,这是 James 一直强调的观点。在2011年敏捷宣言十周年的访谈中,他认为自己与十年前在雪鸟会议的自己相比并没有变化,但他一直拥有自我学习和进步的主人翁意识,在尝试不同的想法并不断完善。所以,敏捷更多是一种前进的方式,而不是可以在此停滞的目的地。回首往事,他不会从《敏捷宣言》中删除任何东西,但会补充一些关于持续改进、适应和学习的内容。如今又是新的十年走过,通过他不断更新的网站和活跃的动态,我们相信他一直在前进,从未停滞。

敏捷史话(十五):我发明了敏捷估算扑克牌 —— James Greening的更多相关文章

  1. 敏捷史话(五):敏捷已逝 —— Dave Thomas

    " 敏捷已逝,但敏捷精神长存.因为所谓的敏捷专家卖给你的是方法论,而不是价值."当多数人都在从"敏捷"身上榨取利益时, Dave Thomas 成为了一位逆行者 ...

  2. 敏捷史话(十四):敏捷之峰的攀登者 —— Jim Highsmith

    "我们希望,一起组成的敏捷联盟能够帮助到其他同行,帮他们用新的更'敏捷'的方式去思考软件开发.方法论和组织.做到这一点,我们就得偿所愿了."Jim Highsmith 在雪鸟会议结 ...

  3. 敏捷宣言(Agile Manifesto)和敏捷开发十二原则

    敏捷宣言 The Agile Manifesto Individuals and interactions over Process and tools 个体与交互 重于 过程和工具 Working ...

  4. 敏捷史话(六):也许这个人能拯救你的代码 —— Robert C. Martin

    Robert C. Martin( 罗伯特·C·马丁),作为世界级软件开发大师.设计模式和敏捷开发先驱.C++ Report杂志前主编,也是敏捷联盟(Agile Alliance)的第一任主席,我们尊 ...

  5. 敏捷史话(四):敏捷是人的天性 —— Arie van Bennekum

    敏捷是人的天性,是你与生俱来的东西.面对敏捷,Arie van Bennekum 下了这样一个结论. 但这并不意味着人们只能通过天赋获得敏捷,对于想要学习敏捷的人来说,敏捷绝不是仅仅靠学习僵化的框架. ...

  6. 提高你开发效率的十五个Visual Studio 2010使用技巧

    提高你开发效率的十五个Visual Studio 2010使用技巧 相信做开发的没有不重视效率的.开发C#,VB的都知道,我们很依赖VS,或者说,我们很感谢VS.能够对一个IDE产生依赖,说明这个ID ...

  7. Docker+ Kubernetes已成为云计算的主流(二十五)

    前言 最近正在抽时间编写k8s的相关教程,很是费时,等相关内容初步完成后,再和大家分享.对于k8s,还是上云更为简单.稳定并且节省成本,因此我们需要对主流云服务的容器服务进行了解,以便更好地应用于生产 ...

  8. 如鹏网学习笔记(十五)ASP.NET MVC核心基础笔记

    一.ASP.Net MVC简介 1,什么是ASP.NET MVC? HttpHandler是ASP.net的底层机制,如果直接使用HttpHandler进行开发难度比较大.工作量大.因此提供了ASP. ...

  9. CODING 敏捷实战系列课第五讲:敏捷中国史

    敏捷软件开发方法自 2001 年传入中国以来,历经十多年的发展变迁,目前已经成为国内 IT 企业主流的研发管理方法.敏捷方法的传播和发展历程,是中国 IT 行业发展的剪影.CODING 特邀敏捷顾问. ...

随机推荐

  1. js 一元运算符

    一元运算符还有一个常用的用法就是将自执行函数的function从函数声明变成表达式. 常用的有 + - - ! void + function () { } - function () { } ~ f ...

  2. Linux-两种磁盘分区方式

    Linux文件设备 要理解Linux,首先要理解Linux文件结构 在Linux操作系统中,几乎所有的设备都位于/dev目录中 名称 作用 位置 SATA接口 电脑硬盘接口 /dev/sd[a-p] ...

  3. go的循环

    目录 go的循环 一.语法 二.语法简写 1.省略第一部分 2.省略第二部分 3.省略第三部分 4.全省略:死循环 5.终极写法,简洁变形 go的循环 Go中只有for循环,没有while循环.因为w ...

  4. 5G时代,为什么NoSQL和SQL存在短板?

    01 介绍 当今的通信服务提供商(CSP)需要能够在处理海量复杂的数据的同时,不会下降或者减慢网路响应速度和可靠性.5G时代,设备和用户数量呈指数级增长,这对业务支持服务(BSS)提出了新需求,也成为 ...

  5. 关于KMP算法中,获取next数组算法的理解

    参考:KMP入门级别算法详解--终于解决了(next数组详解) https://blog.csdn.net/lee18254290736/article/details/77278769 在这里讨论的 ...

  6. 01----python入门----python安装与初识

    ----python入门----python安装与初识 python是一门编程语言,作为学习python的开始,需要事先搞明白:编程的目的是什么?什么是编程语言?什么是编程? 这是一个很好的开头!但是 ...

  7. SpringBoot启动流程分析原理(一)

    我们都知道SpringBoot自问世以来,一直有一个响亮的口号"约定优于配置",其实一种按约定编程的软件设计范式,目的在于减少软件开发人员在工作中的各种繁琐的配置,我们都知道传统的 ...

  8. Apache配置 2.用户认证

    1.用户认证用来对某些目录中的网页进行访问控制,当用户访问这些页面的时候需要输入用户名和密码进行认证. 2. 配置: # vim /usr/local/apache2.4/conf/extra/htt ...

  9. H5 简单实现打砖块游戏

    实现效果如图所示: 1.布局 在html中,声明  div1 作为作为带有边框的父物体,一切行为都要在 div1 中进行.创建小球ball.左右可滑动的板子bat,以及存放要销毁的砖块的父物体 bri ...

  10. vue 页面生成图片保存

    需求:将页面中的元素转成图片,支持保存或下载.要求下载的图片包含页面背景,头像,用户名,文本为"我的邀请码"和个人二维码. 实现:将页面绘制到canvas中,生成base64图片链 ...