`
run_xiao
  • 浏览: 194849 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

在幼儿园学会的结对编程

阅读更多

在幼儿园学会的结对编程

<o:p></o:p> 

英文原文dhttp://collaboration.csc.ncsu.edu/laurie/Papers/Kindergarten.PDF

读来觉得有点意思,翻译了一下,与大家共享。

1986年,Robert Fulghum出版了一本《那些人生中最重要的道理我在幼儿园里都学过(All I Really Need to Know I Learned in Kindergarten)》的书籍。它包含了一些非常棒的思想。Laurie A. WilliamsRobert R. Kessler1999年發表的文章All I Really Need to Know about Pair Programming I Learned In Kindergarten》模仿該書風格對結對編程做出了生動的詮釋。<o:p></o:p>

摘要<o:p></o:p>

共享(Share everything<o:p></o:p>

公平的游戏(Play fair<o:p></o:p>

不要打击别人(Don’t hit people<o:p></o:p>

把东西放回你发现他们的地方(Put things back where you found them<o:p></o:p>

清除你自己的垃圾(Clean up your own mess<o:p></o:p>

不要拿不属于你的东西(Don’t take things that aren’t yours<o:p></o:p>

当你伤害了别人的时候要说对不起(Say you’re sorry when you hurt somebody<o:p></o:p>

飯前洗手(Wash your hands before you eat.<o:p></o:p>

冲洗(Flush<o:p></o:p>

热曲奇和冷的牛奶对你有好处(Warm cookies and cold milk are good for you<o:p></o:p>

过平衡的生活-每天學一些,思考一些,畫唱玩跳,工作(Live a balanced life learn some and think some and draw and paint and sing and<o:p></o:p>

dance and play and work every day some.<o:p></o:p>

每天下午午睡片刻(Take a nap every afternoon<o:p></o:p>

過馬路看紅燈,手掺手(When you go out into the world, watch out for traffic, hold hands and stick together<o:p></o:p>

意识到奇迹(Be aware of wonder<o:p></o:p>

<o:p> </o:p>

簡介<o:p></o:p>

结对编程是一个编程模式。两个程序员并排坐在一台电脑前,面对同一个显示器,使用同一个键盘,同一个鼠标一起工作。他们一起分析,一起设计,一起写测试例子,一起编码,一起单元测试,一起整合测试(Integration Test),一起写文档等。基本上所有的开发环节都一齐肩并肩地,平等地,互补地进行开发工作。這種方式已被證實可以提高軟件產品的生産效率和質量。Williams(本文作者之一)在1999年所做的調查表明,100%PPer在使用這種工作方式時比單獨開發對他們的工作品質更有信心。同時96%認爲更喜歡這樣來工作。然而大多數程序员長期習慣于單獨工作,並抵制先結對編程轉變。本文的目的就是幫助程序員成爲高效的PPer。這種轉變需要每天實踐一些準則,正如上面Robert Fulghum的詩。詩中每行詮釋了成功實施結對開發的必修課。<o:p></o:p>

結對編程成功的證據<o:p></o:p>

衆多轶事趣闻和统计表明PP的益处。XP方法论的成功极大归功于PPXP最初由Smalltalk开发社区和Kent Beck及其同事(Ward Cunningham Ron Jeffries)提出。XP的成功引起了许多德高望重的软件工程研究者和咨询师们的兴趣。XP获得如此名声的典例是于1997年启动的克莱斯勒汽车综合薪资系统(Chrysler Comprehensive Compensation system)。在发现最初开发的重大问题后,BeckJeffries应用XP概念重新启动项目。该系统每月支付超过10000员工的薪水,有2000个类和30000个方法,1998年按时投入使用直到今天。此外,Ford Motor公司的开发者使用传统瀑布方式,花费四年构建车辆成本和赢利系统(Vehicle Cost and Profit System),以失败收场。而XP开发者使用不到一年时间成功实现了该系统。<o:p></o:p>

XP的成功极大归功于PP。所有代码产品有两个人编写。XP如此热衷于支持PP,以致于原型开发都两个人来做。结对工作一个关键的因素就是持续的Code Review,旁边那个人可发现很多明显的但未被注意到的缺陷,数量之多令人惊讶。Beck1999)的实践结果证明,两个程序员一起工作比单独工作快两倍多,对解决方案的思考多于两次,因此可以预防和发现更多缺陷,产品有更好的品质。<o:p></o:p>

<o:p> </o:p>

共享(Share everything<o:p></o:p>

PP中,两个程序员被安排做一件工作(设计,算法,Coding等)。两个人好像公用同一个大脑,负责这件工作的各个方面:一个人编写代码,而另一个人持续的Review;在这个过程中双方都是平等的。“你的设计有个问题”,“这个问题是你那部分的”,这种言辞或想法是不能接受的。 “我们得改善我们的这个设计”, 会更好。每个人都对整个工作负责。<o:p></o:p>

                                                                 <o:p></o:p>

公平的游戏(Play fair<o:p></o:p>

PP中,有一个人是主控的,他正控制键盘或记录设计思路,同时另一个人持续的Review工作成果。即使当一个人明显比另一个更有经验,轮流“主控”也是很重要的。让一个人只是做观众,会让其感觉此事与己无关,或者自己无关紧要。而且此人也并非只是做一个被动的观众,他是以一直积极的参与其中.“看别人写程序就像看沙漠中的草干死一样有趣”(Beck)。众多PP调查表明,大约90%PPer中最主要的人并非敲键盘的那个人,而是旁边那个做持续的分析,设计和代码Review。“当一个人忙于敲代码时,另外一个则思考更策略层的东西——接下来的开发如何进行?是否会走入死胡同?有没有更好的策略?”(Beck<o:p></o:p>

<o:p> </o:p>

不要打击你的伙伴(Don’t hit your partner<o:p></o:p>

确保你的伙伴集中精力在工作上。毫无疑问,结对工作会使每个人“浪费”更少的时间在读邮件,浏览网页上,因为你的伙伴正等你输入呢。而且每个人都希望对方遵守预定的开发规则。<o:p></o:p>

调查结果表明:“每个人会更努力,因为必须和另一个人保持同样的节奏;没有人会觉得可以偷懒”。因此,提高工作效率和质量是必然的。<o:p></o:p>

<o:p> </o:p>

把东西放回你发现他们的地方(Put things back where you found them<o:p></o:p>

思想是很奇妙的东西。如果你一直思考某件事情,你的大脑就会认为它是真的。假如你一直考虑一些负面的东西,比如“我是个很糟糕的程序员”,不久你的大脑就会相信你了。然而,每当这些东西想溜进你的脑子时,任何人都可以控制自己,把这些东西放回你发现他们该呆的地方——垃圾桶。对众多PPer的调查证实:很难同对自己的技术能力不自信的人一同工作。“如果我和你一起工作,你会发现我从来不处理异常”。这种没有安全感的程序员应该把PP看作一种提高自身技术能力的方式,因为有人会帮助检查代码并反馈给你。一项调查回复:“PP对我来说最棒的就是持续的讨论教会我设计和编程时明确思路,这使我成为更好的程序员”。有两个研究者调查了750名合作工作的程序员发现:使用频率最高和价值最高的沟通是“同行间的讨论”。“面对自己无法单独解决的问题的标准答案是求助于同事”。而在PP中,“被求助的同事”随手可得。两个人一起可以解决无法单独解决的问题,并提升每个人的技术能力。<o:p></o:p>

另一极端思想——“我是个很牛的程序员,与我结对的人都太嫩了”——也应该放回到垃圾桶,否则极可能破坏合作关系. 约翰·冯·诺伊曼(John von Neumann) ,一个伟大的数学家,冯·诺伊曼计算机架构的创始人,常常会认识到自己的不足,让别人Review他的工作。“And indeed, there can be no doubt of von Neumann's genius. His very ability to realize his human limitation put him head and shoulders above the average programmer today . . . Average people can be trained to accept their humanity -- their inability to function like a machine -- and to value it and work with others so as to keep it under the kind of control needed if programming is to be successful<o:p></o:p>

<o:p> </o:p>

清除你自己的垃圾(Clean up your own mess<o:p></o:p>

PPer们常说,这太有趣了,我的同伴发现了这么多明显而愚蠢的问题。相比正式评审会议发现的缺陷,PPer会毫无怨言移除同伴发现的缺陷。现有的软件工程技术很重视缺陷的预防和有效移除,或许PP经典地概括了如何预防和移除缺陷。“给我足够的眼球,曝光所有Bug”。<o:p></o:p>

<o:p> </o:p>

不要太严肃(Don’t take things too seriously<o:p></o:p>

“谦虚编程”(Ego-less programming)——Gerald Weinberg20多年前在《计算机编程心理学》(The Psychology of Computer Programming)中提出思想——在有效实施PP中是必要的。调查表明:过度自我会破坏合作关系。首先,“舍我其谁”的态度会阻碍程序员考虑他人的思路;其次,过度自我的程序员在被质疑时会认为不被信任。<o:p></o:p>

《计算机编程心理学》中讨论一个重要场景是关于Review一个程序员的代码。在糟糕的一天,他被搞得哭笑不得,因为在13行代码中发现了17Bug。最终,修改了这些Bug后,程序顺利通过测试并上线使用。如果这个程序员太自信而不接受这个结果,后果可想而知。让另一个人持续而客观的审核你的设计和代码,是PP的益处之一。“人的眼睛有无穷的力量,可以无视它不想看到的东西;如果让程序员单独工作,会漏掉别人一眼就看明的错误”。<o:p></o:p>

相反,程序员对他的同伴唯唯是诺,唯恐造成紧张气氛,对合作关系同样没有什么好处。在交换思想时,存在争论是正常的。在过度自我和畏畏缩缩中有一个平衡,而PPer会经历一段最初的磨合期才能形成这种平衡。Ward CunninghamXP创始人之一)认为磨合期可能会花几个小时到几天,因人而异,因工作性质而异。<o:p></o:p>

<o:p> </o:p>

当你伤害了别人的时候要说对不起(Say you’re sorry when you hurt somebody<o:p></o:p>

在调查中,96%PPer认为合适的工作间对他们的工作很关键。程序员必须能并排坐在一台电脑前,同时看屏幕,使用同一个键盘,同一个鼠标。下图中,右边的设置要好于左边。<o:p></o:p>

<v:shapetype id="_x0000_t75" stroked="f" filled="f" path="m@4@5l@4@11@9@11@9@5xe" o:preferrelative="t" o:spt="75" coordsize="21600,21600"><v:stroke joinstyle="miter"></v:stroke><v:formulas><v:f eqn="if lineDrawn pixelLineWidth 0"></v:f><v:f eqn="sum @0 1 0"></v:f><v:f eqn="sum 0 0 @1"></v:f><v:f eqn="prod @2 1 2"></v:f><v:f eqn="prod @3 21600 pixelWidth"></v:f><v:f eqn="prod @3 21600 pixelHeight"></v:f><v:f eqn="sum @0 0 1"></v:f><v:f eqn="prod @6 1 2"></v:f><v:f eqn="prod @7 21600

分享到:
评论

相关推荐

    结对编程——敏捷开发.pdf

    结对编程(Pair Programming)是敏捷开发(Agile Development)中的一种实践方法,它是指两名开发者坐在一起,共享一台电脑,共同编写代码的过程。 结对编程的优点: 1. 提高代码质量:通过结对编程,可以减少编码...

    论文研究-结对编程开发人员之间若干关系问题的探讨 .pdf

    敏捷软件开发方法中,结对编程是一种实践,它要求两名开发人员在同一台计算机上协同工作。这一方法源自于国际大学生程序设计竞赛(ACM/ICPC)中的团队合作模式。结对编程强调的是两个人的协作,与传统方式相比,它...

    XP实践结对编程demo

    在"XP实践结对编程demo"中,我们可以看到两个关键的目录——`src`和`test`。`src`目录通常包含项目的主要源代码,而`test`目录则用于存放测试代码。在XP实践中,测试驱动开发(TDD, Test-Driven Development)是另一...

    交换编程-结对编程的延伸实践

    交换编程作为一种结对编程的延伸实践,不仅继承了结对编程的优势,还在一定程度上解决了人力资源利用效率的问题。通过合理的任务分配和轮换机制,可以在保证项目质量的同时提高开发效率。对于那些希望提高团队协作...

    2020级计算机系软件工程第二次结对编程作业.zip

    2020级计算机系软件工程第二次结对编程作业.zip 2020级计算机系软件工程第二次结对编程作业.zip 2020级计算机系软件工程第二次结对编程作业.zip 2020级计算机系软件工程第二次结对编程作业.zip 2020级计算机系软件...

    幼儿园师徒结对记录文本.pdf

    幼儿园师徒结对记录文本.pdf

    结对编程与应用

    是软件工程中结对编程与应用的描述与实现方法

    结对编程技术与策略pdf

    在当今快速发展的软件行业中,结对编程作为一种新兴的协作开发模式,正逐渐受到广泛关注。这种开发方式不仅改变了传统意义上的个体开发流程,而且也在软件工程领域内引发了深远的影响。本文旨在深入探讨结对编程的...

    结对编程方法在C语言教学中的应用.pdf

    结对编程方法在C语言教学中的应用 结对编程方法在C语言教学中的应用是计算机专业基础必修课《C语言程序设计》的教学中引入的一种新颖的教学方法。该方法的提出是为了提高学生的编程能力和兴趣,提高教学效果。结对...

    结对编程在数据结构教学中的应用.pdf

    在数据结构的教学实践中,结对编程(Pair Programming)是一种极为有效的教学方法。结对编程是极限编程(Extreme Programming)实践中的一个环节,不仅能够帮助学生更快地掌握编程技能,还能够显著提升他们的团队...

    结对编程在Java Web开发课程实践教学中的应用.pdf

    "结对编程在Java Web开发课程实践教学中的应用" 结对编程是一种敏捷软件开发方法,它在Java Web开发课程实践教学中有着重要的应用价值。本文将对结对编程在Java Web开发课程实践教学中的应用进行探讨,并对其效果...

    自组织团队与松结对编程 陈勇 2011-09-18

    在实践中,将自组织团队理念与松结对编程方法相结合,可以进一步提升软件开发团队的工作效率和产品质量。 **应用实践案例:** 1. **角色分配与轮换**:团队内部可以根据成员的能力和兴趣进行角色分配,并定期进行...

    在复杂的项目开发中使用结对编程

    ### 结对编程在复杂项目开发中的应用 #### 一、结对编程概述 结对编程是一种极限编程(Extreme Programming, XP)技术,它要求两位开发者共同在一个工作站上合作完成编程任务。一位开发者负责编写代码(驱动者),...

    结对编程启示录

    "结对编程启示录"这本书深入浅出地探讨了这一主题,为小团队提供了宝贵的资源,帮助他们在有限的人力条件下产出高质量的代码。 结对编程的核心思想是两个开发者共享一个工作空间,同时在一台计算机上进行编程。一人...

    Addison Wesley - 结对编程启示录(手册)

    结对编程(Pair Programming)是极限编程(XP,Extreme Programming)的一个核心实践,通过两个人共同在一个工作站上编写代码,实现知识共享、即时错误检测和团队协作的增强。 1. **结对编程的基本概念**: 结对...

    结对编程.zip

    结对编程

    创新结对编程在高职《C语言程序设计》课程实践教学中的实现.pdf

    结对编程在高职《C语言程序设计》课程实践教学中的实现,是一种针对软件技术专业学生在团队协作精神方面的培训方法。这一方法主要针对的是当前高职学生普遍缺乏团队协作精神的问题,通过将结对编程技术融入《C语言...

Global site tag (gtag.js) - Google Analytics