细节决定成败!一名开发者从做技工的父亲那里学到的 5 堂课

转载 2012年03月28日 08:59:31

所谓“隔行如隔山”,其实不然,在工作和生活中,大部分的知识和技能都是相通的。学会举一反三,对于技能的提升有很大帮助。本文是一名软件开发者从做技工的父亲身上学到的一些经验,而这些经验使他最终成为了开发者中的佼佼者。

以下为文章全文:

我的父亲是一名工程师——是机械工程师,不是软件工程师。在他成为机械工程师之前,他也做过技工和木工。他很聪明,同时在建筑和维修方面也很有天赋(只要不涉及到电气即可,不过那就是另外一回事了)。他甚至在60岁时依然能做围墙、工棚和甲板之类的工作。当我和我的兄弟还小的时候,他就开始让我们接触一些他工作用的工具,因此,当我们发现需要修复或制作一些东西时,我们有能力做好它。好吧,虽然他在我身上的教育几乎失败,但一路走来,我还是学到了很多重要的东西,而且,不管你信不信,这些我学到的东西,在我成为一名优秀的开发者和企业家的路上,让我受益良多。

下面就是我从他那里学到的知识。

第一课:三思而后行

砍柴是一个一次性的工作。只要树木被砍掉,它就不可能再保持原样。因此,很重要的一件事就是确保你每一次的删除操作是无误的。甚至即使你确定你的做法是正确的,也请你无论如何再做一次评估。重新检查你的评估,确保它正确无误,这样你就可以避免犯一些本可以规避掉的错误,付出的代价也要小的多。

开发产品也是同样的道理。如果事先不测量书架要占用的空间的大小,你怎能做出与之大小相适合的书架?如果事先不知道用户的需要,你又何必去开发一个无用的产品?这个道理已经提过很多次了,我在这里略过。但有个不被经常提及的事情是你的产品是一组功能的集合体,就像书架是一堆货架的集合体一样。每一个功能都应该被认真对待,细心评估,以确保它适用于受众人群。重要的是不仅仅在项目开始就收集反馈,在整个项目的开发阶段,我们都要重视反馈,而不是等到结束了,才想起还有一些不错的创意没有实现。

第二课:粉刷一座建造好的凉亭会很困难

有一次,几个工人在家里修凉亭,他们在凉亭建好后才开始粉刷。爸爸看到后指出,如果这些工人能在这些木头放在地面上就开始粉刷的话,他们就能节约1/10的时间,而且效果也会更好。粉刷之后只需做一些连接工作就可以很快的建造起这座凉亭。粉刷已经建造好的凉亭不仅又慢又不方便,而且还可能导致出现一些不易刷到的地方,最糟糕的是,如果不幸的话,还会把这一切弄得一团糟。

在产品的开发过程中,很容易忘记设计和UI,但这些很重要。以用户为中心的设计就是在设计页面时,以服务用户为第一要务,然后再开发相应的应用来支持这一设计。而以软件开发为优先并把设计放到最后,你将做更多的工作,产品也会存在潜在的缺点。UX应该是一个持续不断的过程,不是某个可以随意丢弃的东西。

第三课:让你的项目和工作空间始终保持整洁

在一个杂乱的环境中工作一定会让你的项目结果变得一团糟。如果碎木屑到处都是,你就不可能粉刷好;如果你的工具都满覆油污,你就不可能把拆散的发动机零件再组装到一起;如果你用完工具后不搜集整理好,你可能永远都找不到你想要的螺丝刀。任何一个机修工都会告诉你工作在一个整洁的环境中有多么重要。糟糕的不止是你将花更多的时间用于寻找放错位置的工具,还会导致更多的损失。

每一个开发者的代码中都可能会有一些bug。很多开发者都知道“代码债务”这个名词,它实际上只是从开发者的角度来看待这一块工作混乱的区域。如果你在源头埋下隐患,所造成的后果不仅仅是更难发现bug,而且在将来会更容易造成更多的混乱。最终你将不得不清理它们(特别是在你开始你自己的工作前,你将不得不去清理其他人留下的这些bug!)。想必每一个开发者都知道修改别人代码时那种恐怖的感觉,并会意识到他们留下了一堆麻烦等着你去解决。现在花一点时间去整理你的工作空间,将来你会节约更多的时间。

第四课:始终使用正确的工具(而且在你的工具上别吝啬)

搞砸工作的一个主要原因就是使用了不恰当的工具。这虽然显而易见,但很多人就是意识不到这一点。用错了工具后的下场通常是一个灾难。别心疼钱,工作一展开就应该找到合适的工具。

工具选用不当虽然通常都是管理层犯下的错误,但我们开发者也要为此事负责。毫无疑问,一个用了6年的笔记本运行起来肯定会很慢。即便为一款文本编辑器花了10美元,但却选用了最蹩脚的一款,也不会有助你的工作。节省的这几块钱不会帮你赢得客户的心。最糟的是,利用盗版软件帮你赚钱,这是完全错误的做法。今天你可能觉得你节省了一些,但在以后的运营中一定会花掉你更多的钱。找出最适合你项目的开发工具,然后花一些钱(除非它是开源的!)。当项目开始后,节约会特别具有挑战性。除非你需要,否则别乱花钱,但如果有些工具需要花钱才能使用,那就要选最好的。

第五课:如果方法都不奏效,那么去找一个更大的锤子

有时候你卡住了,这意味着你碰到了难题。有时候不管你多么用力,都无法将螺栓拧入螺孔中。有时候不管你多么用力敲打,钉子都不会被敲入。这时候你仅仅需要一把更大、更合适的锤子。

作为BugHerd的创始人之一,我过去常碰到一些本该寻求帮助的情况。但我挣扎着,我通读手册,看视频录像并参阅博客文章。然后我清醒了,并意识到无论我做什么,肯定有其他人在这方面做得比我好。目前,我们有2位精通JS的同事,他们做的工作,比我们任何时候做的都要好。有很多为远程团队协作而准备的优秀的工具,因此,不要找借口说没有合适的同事和你一起工作。有时候,你仅仅需要接受现实,并找到相应的解决办法。

作为一个活跃在专业开发设计社区里的创业者,我常感到像活在培养皿里。偶尔停下来,观察一些较为传统的行业,看看我们能从那些做出卓越贡献的前辈那里学到什么,这也是一个不错的做法。无论我们认为我们有多聪明,也不论他们有哪方面的优点,我们总是能从这些前辈这里学到很多。

英文原文:How lessons from a tradesman can help out a techie

文章来源:iteye.com

一名开发者从做技工的父亲那里学到的 5 堂课

所谓“隔行如隔山”,其实不然,在工作和生活中,大部分的知识和技能都是相通的。学会举一反三,对于技能的提升有很大帮助。本文是一名软件开发者从做技工的父亲身上学到的一些经验,而这些经验使他最终成为了开发者...
  • DavidHsing
  • DavidHsing
  • 2012年03月27日 17:23
  • 853

一名开发者从做技工的父亲那里学到的5堂课

转载 http://kb.cnblogs.com/page/136696/   一名开发者从做技工的父亲那里学到的5堂课 作者: Alan Downi  来源: ITeye  发布时间: 201...
  • cai5
  • cai5
  • 2012年03月30日 14:59
  • 486

细节决定成败--职场心得

今天SA临时给我安排了一个超级“轻松”的工作。公司每年每月都会有合同到期的员工,如果这些员工想要继续 在公司工作就需要进行合同续签。由于合同续签流程涉及到相关环节的审批人都是公司高层,所以发送的审批请...
  • u010773667
  • u010773667
  • 2015年08月16日 17:25
  • 463

再读《细节决定成败》有感

       2004年当我刚进入公司的时候就被同事桌子上摆放的《细节决定成败》所吸引,于是借来一边读一边反思着前六年的研发生涯,如醍醐灌顶般,一口气读完,当合上最后一页的刹那,心中也随着豁然开朗。从...
  • blueluhan
  • blueluhan
  • 2009年04月08日 10:37
  • 3880

习惯决定性格,性格决定命运,细节决定成败!

今天,把这句话放到了博客的标题上。这句话,我是从阿朱的《走出软件作坊》上看来的。这句话原话应该是大家经常看到的所谓古人云:积行成习,积习成性,积性成命。这里说的是习惯决定性格,而一般人总是认为性格决定...
  • lanman
  • lanman
  • 2009年02月21日 21:07
  • 5201

信息化管理中细节决定成败

沃尔玛于20世纪60年代创建,在20世纪90年代一跃成为美国第一大零售商。在短短几十年的时间里,沃尔玛的连锁店几乎遍布全世界,并以其优质快捷的服务、惊人的销售利润、先进的管理系统而闻名全球。如今,在“...
  • goodman1999
  • goodman1999
  • 2008年10月20日 18:21
  • 469

其实性格决定命运,细节决定成败,知识改变命运,学习成就未来,观念决定行动,思维决定出路,态度决定一切

其实性格决定命运,细节决定成败,知识改变命运,学习成就未来,观念决定行动,思维决定出路,态度决定一切,他们唯一的目的是要你认清自己的短处,发挥自己的长处,慢慢改正自己的缺点。以文章《变色龙》为例,如果...
  • xiejinfeng850414
  • xiejinfeng850414
  • 2014年05月21日 22:16
  • 4040

12堂思维课的读后点滴

1.思维模式的观点:每个人面对不同的事情所作出的思维的反应,可以归结为从众多的思维模式中进行选择,选择一个最为相似的模式。因此,我们的思考就好像是在不断进行模式识别,然后做出反应。而模式的不同,可能会...
  • stonesix
  • stonesix
  • 2015年07月07日 21:51
  • 168

软件设计是怎样炼成的(7)——细节决定成败(详细设计)

当我们需要考虑类、类的内部细节、类之间的关系时,这时我们已经开始做详细设计了。详细设计不一定是一份文档,也不一定是Word文档,详细设计也不一定叫“详细设计”,有时候“编码就是设计”也是未尝不可的。对...
  • u010825142
  • u010825142
  • 2014年03月04日 01:13
  • 12463

07、刘媛媛《普通人快速崛起31节修炼课》 第七讲 个人学习笔记

克服拖延症: 拖延症的诞生: 很爽、伴随着内疚。会陷入一种怪圈,一次又一次地发生。 拖延症带来的: 1、怪圈、永远都平庸人生,永远无法自拔。 2、在这个社会即使你...
  • bgsux
  • bgsux
  • 2018年01月03日 10:41
  • 487
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:细节决定成败!一名开发者从做技工的父亲那里学到的 5 堂课
举报原因:
原因补充:

(最多只允许输入30个字)