《高效能程序员的修炼》一第一条法则:永远都是你的错

第一条法则:永远都是你的错

高效能程序员的修炼
作者在Twitter上发的一条短讯:

“在怨天尤人之前,我们应该先自我反省、努力把自身的问题解决了。”

12:22 PM – 2012-5-30

你应该知道那种感觉。我们所有人都曾碰到过这样的事情:已经盯着代码看了无数遍,但还是没有发现任何问题。然而,有个故障或者错误始终挥之不去。于是你开始怀疑,可能是你开发程序所用的那台机器出了问题,也可能是操作系统的问题,或者是你使用的工具和库出了问题。肯定是它们的原因!

然而,无论你多么绝望,都不要往那条路上走。沿着那条路下去就是“伏都1”计算和靠运气编程。

总是要处理一些困难的、捉摸不透的问题,这是一件令人绝望的事情,但是不要让绝望领着你误入歧途。作为一名谦逊的程序员,最基本的要求就是要有意识:你写的代码在任何时候出了问题,那一定都是你的错。这个观点在《程序员修炼之道:从小工到专家》2一书中被巧妙地归结为“select3没有问题”:

在大多数项目中,你所调试的代码里常常混杂着这些东西:你和项目小组中的其他成员开发的应用代码、第三方的产品(数据库、链接器、图形库、特殊的通信系统或者算法等)以及平台环境(操作系统、系统库和编译器)。

操作系统、编译器或者第三方产品出问题的可能性是有的——但是,这绝对不应该是你碰到问题后的第一反应。错误出现在正在开发的应用代码中的可能性要大得多。通常情况下,假定应用程序错误地调用了库函数要比假定库本身有问题更有效益。即便问题出在第三方,你还是必须彻底排除自身代码的问题,然后再提交错误报告。

我们曾经做过一个项目,项目中的一位高级工程师确信Solaris4上的select系统调用出了问题。无数次的劝说和逻辑分析都不能改变他的主意(事实上,所有其他的网络应用程序在同样的机器上都能正常工作,但他仍然固执己见)。他花了好几个星期来做变通方案,但是因为一些诡异的原因,这些方案似乎都行不通。他最终不得不坐下来,仔细地阅读关于select的文档。终于,他找到了真正的问题,并且在几分钟内就解决了。如今,一旦我们当中有人开始为了一个很可能是我们自己造成的错误而责怪系统时,我们都会用“select有问题”这个短语作为善意的提醒。

代码产权的另一面是代码责任。无论你的软件出现什么样的问题——甚至最开始出错的地方根本就不是你的代码——你也应该总是假定问题出在你的代码里,并且根据这个假设采取行动。如果你想让世界人民接受你的软件,那你就要为它的故障承担全责。尽管——从严格意义上来说——你并不是非这么做不可。但只有这样,你才能赢得尊敬和信任。如果你不断地把问题推卸到其他人、其他公司或者其他源头上,你是无论如何也得不到尊敬和信任的。

从统计学的角度来说,软件中的故障或者错误一般都是人为的,例外的可能性可谓凤毛麟角。我想你已经明白了这一点。在《代码大全》(《Code Complete》)一书中,Steve McConnell引用了两个研究来证明这个观点:

通过1973年和1984年进行的两次研究发现,在所有报告的错误中,大约有95%是由程序员造成的,2%是由系统软件(编译器和操作系统)造成的,2%是由其他软件造成的,1%是由硬件造成的。跟20世纪70年代和80年代相比,现在的系统软件和开发工具的使用人群要大得多,所以我猜想,现如今应该有更高比例的错误是由程序员的过失造成的。

不管你的软件出了什么问题,请你负起责任来吧!从你的代码开始,深入进去,逐步向外调查,直到你找到确凿的证据证明问题之所在。如果问题出在你无法控制的代码上,你不但学会了必要的故障排除和诊断技巧,同时还获得了用来支持你指控别人的审计证据。当然,和你耸耸肩膀简单地把问题归责于操作系统、工具或者应用框架相比,这样花费的工夫要多得多——但是这也会逐步形成信任和尊敬的感觉,而这种感觉是你通过指责他人和逃避无法体会到的。

如果你真的渴望做一名谦逊的程序员,在你碰到问题的时候,你就应该很淡定地说:“嘿,这是我的错——让我把它弄个水落石出。”

时间: 2024-09-11 20:30:56

《高效能程序员的修炼》一第一条法则:永远都是你的错的相关文章

《高效能程序员的修炼》一向橡皮鸭求助

向橡皮鸭求助 高效能程序员的修炼 在Stack Exchange上,我们坚持要求提出问题的人需要在自己的问题上多下些功夫,而且我们在这方面有些偏执.那就是说,当你开始要提问题的时候,你应该: 用足够多的细节来描述发生的状况,这样我们可以顺着你的描述继续研究下去.即使在你所在的特定领域里我们并不是专家,你也要向我们提供必要的背景情况,这样我们可以了解到底发生了什么事情. 告诉我们你为什么需要知道答案.你怎么会出现在这里?是闲来无事的好奇,还是在某个项目里遇到了障碍?我们不是要求你长篇大论地讲生活故

《高效能程序员的修炼》一一路向前冲

一路向前冲 高效能程序员的修炼就运营Stack Overflow这个公司而言,我采用的商业策略全来自一个人,而且只有这一个人:Curtis Armstrong. 更准确地说,是Curtis Armstrong在1985年的经典荒诞青春喜剧<再见人生>(<Better Off Dead>)中所扮演的Charles De Mar.当他被问到如何从一个特别险峻的高山上滑雪下去的时候,他回答道: 沿着那条路下去,一定要快.如果有什么东西挡住了你的去路--绕开它! 在我们宣布Stack Ov

《高效能程序员的修炼》一性能致胜

性能致胜 高效能程序员的修炼在Stack Overflow和Stack Exchange上,我们总是非常强调性能.不仅仅因为我们是性能的发烧友(我很内疚),也因为我们认为速度是一个竞争优势.已经有大量的实验数据表明,网站载入和显示的速度越慢,使用它的人就会越少. Google发现,显示10个结果的网页需要0.4秒来生成,显示30个结果的网页需要0.9秒来生成.半秒钟的延迟会造成20%的流量下降.半秒钟的延迟就扼杀了用户的满意度. 在A/B1测试中,亚马逊试着以100毫秒为单位逐步增加页面的延迟,

《高效能程序员的修炼》一学会读源代码

学会读源代码 高效能程序员的修炼在"沟通"这个复杂的领域里,写出能让人类领会并理解的连贯段落比敲出几行不至于让解释器或编译器"呕吐"的软件代码要难得多. 这就是为什么--就软件开发而言--所有的文档大概都是很差劲的.而且,由于为人写作比为机器写作要困难得多,恐怕在可预见的将来,文档还会继续差劲下去.对此,你基本上是无能为力的. 除了做一件事-- "卢克1,学着去读源代码." JavaScript"始终带有源代码"是一股革命性的

《高效能程序员的修炼》一导读

译者序 高效能程序员的修炼出版社的冀康一开始来找我谈翻译这本书的时候,我的第一反应是:这兄弟真是不知道我现在有多忙!我每天要处理200多封邮件:在资源有限的情况下经常要同时带6-7个项目,而且每个项目的交付计划都很紧,压力很大:每天起码工作12个小时,有时候还要熬夜跟美国同事开会:周六基本上也是工作状态--我哪里还有空来翻译书?! 后来,当我了解到这本书的作者是Stack Overflow网站的创始人Jeff Atwood,还有书的内容实际上就是从作者的博客网站Coding Horror精选而来

《高效能程序员的修炼》一你的团队能通过电梯测试吗

你的团队能通过电梯测试吗 高效能程序员的修炼软件开发者们是真心喜爱编写代码的.但根据我的经验,他们当中很少有人可以解释清楚他们为什么在编写代码.如果你不信,你可以从你的团队里找个人来测试一下:问他在做什么:接着问他为什么要做那个:继续问下去,直到你得到一个可以让你的客户理解的原因. 你在做什么? 我在修复这个数据网格的排序问题. 你为什么要解决这个问题? 因为它在bug清单上. 它为什么在bug清单上? 因为有个测试人员把它作为一个bug报出来了. 为什么它被作为一个bug报出来了? 测试人员认

读书笔记--《高效能程序员的修炼》

        初次邂逅......        最近小编抽空看了一本书,书的名字叫做<高效能程序员的修炼>,从这本书的名字就能看出来,软件开发远不只是写代码那么简单,你要学会的是高效能的工作,这让小编想到了去年读过的一本书<高效能人士的七个习惯>,有兴趣的小伙伴可以看看哦,受益匪浅,<高效能程序员的修炼>这本书从人文角度而非技术角度去阐释了作为一个程序员,应该具备的基本素质,所以小编在看这本书的过程中,感到非常的有共鸣,通俗易懂,又很贴近小逼啊工作和生活中的实际,

《高效能程序员的修炼》一如何培养写作习惯

如何培养写作习惯 高效能程序员的修炼 我得忏悔一下:程序员同胞们,从某种程度上来说,我创办的Stack Overflow网站"耍"了大家. 在你找来棍棒准备揍我之前,请允许我先解释一下. 在过去的6年时间里,我越来越坚定地有了这样一个想法,那就是:成为一名杰出的程序员其实跟写代码没有太大的关系.做程序员确实需要一些技能,当然,还要有坚韧不拔的精神.但除此之外,更重要的还是要有良好的沟通技巧. 杰出的程序员跟勉强过得去的程序员之间的差别,不在于他们掌握了多少种编程语言,也不在于他们谁更擅

《高效能程序员的修炼》一大道至简

大道至简 高效能程序员的修炼 作者在Twitter上发的一条短讯: "你永远都有简化的空间." 11:29 AM – 2012-5-21 Rich Skrenta在"Code is our enemy"(代码是我们的敌人)一文中是这么说的: 代码不是什么好东西.代码会随着时间的推移慢慢腐烂.代码需要周期性的维护.代码里还藏有bug.新增功能意味着旧的代码需要被修改.你的代码越多,bug能藏身的地方就越多,迁出(checkout)或者编译的时间也就越长,新员工理解你的