大家论坛

 找回密码
 注册
查看: 5569|回复: 16

[推荐] 《程序员修炼之道--从小工到专家》

[复制链接]
发表于 2009-9-25 21:31 | 显示全部楼层 |阅读模式
程序员修炼之道--从小工到专家》样章连载


第1章  注重实效的哲学


     注重实效的程序员的特征是什么?我们觉得是他们处理问题、寻求解决方案时的态度、风格、哲学。他们能够越出直接的问题去思考,总是设法把问题放在更大的语境中,总是设法注意更大的图景。毕竟,没有这样的更大的语境,你又怎能注重实效?你又怎能做出明智的妥协和有见识的决策?
  他们成功的另一关键是他们对他们所做的每件事情负责,关于这一点,我们将在“我的源码让猫给吃了”中加以讨论。因为负责,注重实效的程序员不会坐视他们的项目土崩瓦解。在“软件的熵”中,我们将告诉你怎样使你的项目保持整洁。
  大多数人发现自己很难接受变化,有时是出于好的理由,有时只是因为固有的惰性。在“石头汤与煮青蛙”中,我们将考察一种促成变化的策略,并(出于对平衡的兴趣)讲述一个忽视渐变危险的两栖动物的警世传说。
  理解你的工作的语境的好处之一是,了解你的软件必须有多好变得更容易了。有时接近完美是唯一的选择,但常常会涉及各种权衡。我们将在“足够好的软件”中探究这一问题。
  当然,你需要拥有广泛的知识和经验基础才能赢得这一切。学习是一个持续不断的过程。在“你的知识资产”中,我们将讨论一些策略,让你“开足马力”。最后,我们没有人生活在真空中。我们都要花大量时间与他人打交道。在“交流!”中列出了能让我们更好地做到这一点的几种途径。
  注重实效的编程源于注重实效的思考的哲学。本章将为这种哲学设立基础。

01  我的源码让猫给吃了

在所有弱点中,最大的弱点就是害怕暴露弱点。
  ——J. B. Bossuet, Politics from Holy Writ, 1709

  依据你的职业发展、你的项目和你每天的工作,为你自己和你的行为负责这样一种观念,是注重实效的哲学的一块基石。注重实效的程序员对他或她自己的职业生涯负责,并且不害怕承认无知或错误。这肯定并非是编程最令人愉悦的方面,但它肯定会发生——即使是在最好的项目中。尽管有彻底的测试、良好的文档以及足够的自动化,事情还是会出错。交付晚了,出现了未曾预见到的技术问题。
  发生这样的事情,我们要设法尽可能职业地处理它们。这意味着诚实和坦率。我们可以为我们的能力自豪,但对于我们的缺点——还有我们的无知和我们的错误——我们必须诚实。
负责  责任是你主动担负的东西。你承诺确保某件事情正确完成,但你不一定能直接控制事情的每一个方面。除了尽你所能以外,你必须分析风险是否超出了你的控制。对于不可能做到的事情或是风险太大的事情,你有权去为之负责。你必须基于你自己的道德准则和判断来做出决定。
  如果你确实同意要为某个结果负责,你就应切实负起责任。当你犯错误(就如同我们所有人都会犯错误一样)、或是判断失误时,诚实地承认它,并设法给出各种选择。不要责备别人或别的东西,或是拼凑借口。不要把所有问题都归咎于供应商、编程语言、管理部门、或是你的同事。也许他(它)们全体或是某几方在其中扮演了某种角色,但可以选择提供解决方案,而非寻找借口。
  如果存在供应商不能按时供货的风险,你应该预先制定一份应急计划。如果磁盘垮了——带走了你的所有源码——而你没有做备份,那是你的错。告诉你的老板“我的源码让猫给吃了”也无法改变这一点。

提示3

Provide Options, Don’t Make Lame Excuses
提供各种选择,不要找蹩脚的借口


   在你走向任何人、告诉他们为何某事做不到、为何耽搁、为何出问题之前,先停下来,听一听你心里的声音。与你的显示器上的橡皮鸭交谈,或是与猫交谈。你的辩解听起来合理,还是愚蠢?在你老板听来又是怎样?
  在你的头脑里把谈话预演一遍。其他人可能会说什么?他们是否会问:“你试了这个吗……”,或是“你没有考虑那个吗?”你将怎样回答?在你去告诉他们坏消息之前,是否还有其他你可以再试一试的办法?有时,你其实知道他们会说什么,所以还是不要给他们添麻烦吧。
  要提供各种选择,而不是找借口。不要说事情做不到;要说明能够做什么来挽回局面。必须把代码扔掉?给他们讲授重构的价值(参见重构,149)。你要花时间建立原型(prototyping),以确定最好的继续前进的方式(参见原型与便笺,40)?你要引入更好的测试(参见易于测试的代码,153页;以及无情的测试,191)或自动化(参见无处不在的自动化,186),以防止问题再度发生?又或许你需要额外的资源。不要害怕提出要求,也不要害怕承认你需要帮助。
  在你大声说出它们之前,先设法把蹩脚的借口清除出去。如果你必须说,就先对你的猫说。反正,如果小蒂德尔丝(TiddlesBBC1969~1974年播出的喜剧节目“Monty Python’s Flying Circus”中的著名小母猫——译注)要承受指责……

相关内容:
l原型与便笺,40
l重构,149
l易于测试的代码,153
l无处不在的自动化,186
l无情的测试,191

挑战
l如果有人——比如银行柜台职员、汽车修理工或是店员——对你说蹩脚的借口,你会怎样反应?结果你会怎样想他们和他们的公司?

[ 本帖最后由 holly2008 于 2009-9-25 21:35 编辑 ]
回复

使用道具 举报

发表于 2009-10-11 00:52 | 显示全部楼层
不错,下载了
回复

使用道具 举报

发表于 2009-11-11 15:01 | 显示全部楼层
楼上你怎么下载的???
回复

使用道具 举报

发表于 2009-11-20 10:52 | 显示全部楼层
回复 1# holly2008

楼主,怎么不提供下载呀
回复

使用道具 举报

发表于 2010-4-29 13:28 | 显示全部楼层
,怎么不提供下载呀
回复

使用道具 举报

发表于 2010-8-7 16:08 | 显示全部楼层
回复

使用道具 举报

发表于 2010-8-25 10:32 | 显示全部楼层
呃...  我有,不过我现在级别不够,不能上传附件,等我有权限了我就放上来好了...
回复

使用道具 举报

发表于 2010-9-2 20:28 | 显示全部楼层
回复

使用道具 举报

发表于 2011-2-13 12:19 | 显示全部楼层
回复

使用道具 举报

发表于 2011-2-15 20:28 | 显示全部楼层
这本书很不错,如果有,请提供分享,谢谢
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则



诚聘英才|移动端|Archiver|版权声明|大家论坛 ( 京ICP备06071611号,京公网安备11010802018363号

GMT+8, 2017-9-27 01:53 , Processed in 0.538616 second(s), 17 queries .

Powered by Discuz!

© Comsenz Inc.

快速回复 返回顶部 返回列表