编程道场介绍
编程道场(Coding Dojo)——围绕着小规模的编程主题,各种不同水平的程序员组织到一起探讨其解决方案,并采用TDD、结对编程、快速迭代等敏捷实践将其实现的一种活动。
国外组织编程道场活动的一些规则:
- 参与人数不超过15人
- 编程挑战的主题会预先告知
- 活动之前会预先公布即将进行的活动采用的编程语言
- 实际的编程以迭代的形式进行,在每个编程迭代前,可以有一段简短的计划时间
- 主持人起项目所有者的作用
- 活动房间内有一台计算机连到大屏幕上
- 开始时,主持人解释编程挑战内容,然后从与会人中挑选二人开始结对编程
- 上场的二人必须使用测试驱动开发(TDD)
- 每5分钟换掉其中一人
- 上场的二人要不停地解释他们在做什么
- 观众中有人提问或不理解的话,他们必须中止,直到理解为止
- 编程测试出现绿灯时,观众才能对设计进行评论(在红灯期间观众只可以问问题)
- 观众对当前的设计不满意的话,上场的二人不可以编写新代码(在编写新代码之前,必须对当前代码进行重构)
- 所有的生成的代码在Apache License(2.0版)许可下公开
我参加的第一次编程道场
7月20日下午2点——6点,在上地联想二楼的办公室内,参加了Ben组织的BJDP第17次编程道场,也是我参加的第一次编程道场活动。跟匠友们一起度过了一个热火朝天(会议室里面的确很热,因为没有开空调啊,:()的下午,收益匪浅,基于分享的精神,我把活动的流程记录下来,以供有兴趣的同学参考。
- 每个人到了之后先到前面的白板上把自己的名字写下来。
- 然后到支持人(Ben作为主持人,小泽匠友协助他主持)那里领一张粘贴纸,把自己的名字写上去,贴到自己的胸前,以方便其他的匠友认识你。
- 自己找位置坐下,等待其他的匠友,等待活动正式开始。
- 下午2点,活动正式开始。主持人给每一个到会的匠友发一张白纸和一支白板笔,让匠友们根据当时的心情画一幅画。对,你没听错,是画一幅画!随便画点什么都行,没有限制,但一会你要解释一下你这幅画的内涵哦。时间限制3分钟。
- 3分钟时间到,主持人开始让每位匠友开始介绍自己,介绍内容如下:
- 你这幅画要表达的内涵是什么
- 你的名字
- 你的公司和职业
- 你擅长的技术领域
- 匠友都介绍完之后,主持人把所有人的画作都收集起来,作为本次编程道场的纪念。
- 在主题开始之前,Ben让每位匠友把工作中关于编程实践上遇到的最典型问题说一两个出来,统一写到前面的白板上。这些问题在代码操练的过程中或者之后根据时机进行探讨和解答。
- Ben开始介绍本次变成编程的主题: 一个气压报警系统的设计和实现。使用TDD、结对编程、快速迭代等方式实现。
- Ben首先做一次TDD的操练,使用gtest对Alerm类的公共接口编写UT(单元测试)。
- Ben做完一个接口的TDD操练后,开始到随机结对编程环节。两个匠友组合一对,开始结对编程,每次7分钟,时间到后切换到下一对,快速进行迭代开发。
- 通过结对编程和持续的快速迭代把所有的接口的UT和内部实现全部完成。
- 接下来Ben给每位匠友发三张便帖,分别写下三方面的内容:
- Well: 你认为本次编程操练的优点是什么?
- Not Well:你认为本次编程操练的缺点是什么?
- Pizzle:你对本次编程操练还有什么疑问?
写完后,Ben把所有人的便帖收上来,贴到前面的白板上,然后一个一个的过,跟大家进行交流
- 最后Ben带领大家把白板上问题再过一遍,大家一起讨论,集思广益,看能不能找到解决的方案。
- 结束活动,各自打道回府。
这时恰好6点钟,不得不佩服Ben对时间和进度上的把控能力,能够有条不紊的把上述活动一一做完。同时也感谢Ben给我提供了一个这么好的学习机会,可以这么近距离的接触TDD、结对编程和快速迭代模式,接触代码操练的这种独特而有魅力的编程实践。
感悟
第一次参加编程道场,应该说是感悟颇多,捡一些干货来说吧:
该实践很好的锻炼了心理素质和语言表达能力。编程道场的目的并不是让大家多么快速地把问题解决掉,最核心的部分却是让大家在一起交流,产生思想的碰撞,共同提高,共同成长。除了开始部分的个人介绍,在结对编程的过程中也需要你大声的说出你的意图,让所有匠友明白你的意图,如果其他任何人有疑问,你就需要停下来解释清楚。这种面对面的激烈的思想碰撞,对于我们的心理素质的提高和语言表达能力的锤炼,是多么难得的机会。
该实践让我领悟到慢下来也可能是一种很好的状态。快,是现代大多数人的追求,包括我。因为,这是一个逼迫你快起来的时代,什么事情都讲究一个效率。在企业里,管理者让员工尽可能快的去完成一件事情,因为这样成本就更低,投入产出比就更高。程序员写代码也要求快,快速设计、快速实现、快速发布。怎一个快字了得,压的我们喘不过气来。而这里,却让你慢,慢慢的思考,慢慢的操练,不急不躁,稳步前进。甚至于我们已经习惯了快的状态,突然之间切换的慢的频道,竟然有些不适应,总是急着向前奔,带着一份浮躁,带着一颗躁动的心。慢下来,却也可以这样的好。
该实践让我意识到编程语言已经没有了界限,所谓的C/C++、C#、Java等等语言,在代码操练的大师们眼里,只不过都是表达思想的工具,形式各异,本质一致。Ben组织的BJDP编程道场活动,之所以轮流采用C#、C++、Java编程语言进行操练,无非也是想表达这个意思:使用任何的编程语言都无所谓,因为它们只是表达思想的工具。