内疚的程序员

翻译 2012年03月26日 17:59:55

内疚的程序员

我发现,当程序员开发了一个项目,然后要把它移交给其他程序员时,他们会对开发这个项目时做出的一些决策感到内疚。我问他们当时为什么选择这样做,他们会羞愧的说,“唉,我知道这不是最好的实现方法,如果现在再去做,肯定不会采用那样的方式。”有些人可能会辩护,或强调一下外部因素,比如工期压力。但我的观点是,程序员不需要为老的项目感到太多的内疚。

经验

我承认,我曾经有一次重新发球的经验。那是一个作为内部工具使用的Ruby on Rails项目。我之前对这种技术架构了解不多。基本上就是把东西按照需求拼凑起来,它运行很正常。没有多少测试,设计上必然是没有体现出最好的设计原则。但它能用。

接着,我做了一个6个月长的Rails项目,过程完全是TDD的。在此之后,出现了一个机会,需要调整那个内部工具,增加一些功能。

我很高兴有这次机会。我感觉对这种技术有了更好的了解,能够看出代码中存在的问题,知道如何用更好的Rails或Ruby技术来解决这些问题。这让人很兴奋。不止一次,我惊奇于那些老的代码竟然能正常的运行。我想,绝大多数程序员都很少能有这样的机会,除非他们是在维护一个老项目,我想这是一次很有价值的经历,让我在事后看清了我自己写的程序。

综合分析

但后来,我开始意识到,程序员不必要为自己开发出的产品感到内疚。新的技术和实践方法不断的出现,等待着你去学习,每一次你都要权衡取舍,总会有事后诸葛亮的情况出现。我应该现在重构这个类,还是放到以后再说?我是需要把设计的容易扩展,或者根本不需要这样?做这个项目时我们是否应该首先尽量的减少技术上的风险?

在针对某一问题我遍历群书后,对解决这类问题我学会了新的技术,新的方法。但这并不能妨碍我们当前的工作。我们不可能百分百的知道我们所需要的知识,我们能想到的方案只是能满足解决当前问题需求。

我相信,程序员都已经尽了他们最大的努力。但这并不能免除程序员犯错误,并从错误中学到经验,也不能保证他们能够进行先知先觉的学习。

我想说的是,程序员如果没有足够的知识以最佳的方式来解决所有的问题或在困境中做出最正确的抉择,他不必为此不安。在之后的岁月里认识到了自己的错误,这是自己进步的标识。每一次都把事情做的正确无误,这暗示一种技术的停滞,或完美主义。哪一种更有可能?

你是否也有过这样的一种愿望,希望能够重新来一次,改变某个软件项目中的某些东西?有过看着自己写过的代码感到恶心的时候?把事情做对,还是把事情做完?平衡点在哪里?在评论里留下你的想法吧!

[本文英文原文链接:Guilty Developer Syndrome ]

[本文来自:外刊it评论]

相关文章推荐

内疚的程序员

我发现,当程序员开发了一个项目,然后要把它移交给其他程序员时,他们会对开发这个项目时做出的一些决策感到内疚。我问他们当时为什么选择这样做,他们会羞愧的说,“唉,我知道这不是最好的实现方法,如果现在再去...

我包了“二奶”,有点内疚(转)

每个人的人生观或许是会不断的改变的。之前一段时间内,我对见异思迁的人相当鄙视,心想着,坚持一下不也挺好的嘛。相当意外的是,现在的我也成了这种人,竟然包了二奶,人生啊人生,真是惨绝人寰。     先得...

【转】企业要重生,就要鹰一样蜕变——TCL 总裁 :我为什么内疚

文/李东生* 这是一个关于鹰的故事。 鹰是世界上寿命最长的鸟类,它一生的年龄可达70岁。 但它在40岁时必须作出困难而又重要的决定。这时,它的喙变得又长又弯;它的爪子开始老化;它的羽毛长得...

如果你扯了团队后腿,你应该内疚

现在,我看到很多人扯了团队的后腿,一句道歉就了事,更甚者就以另一种方式来表达:你们没有给我足够的培训,你们的工作方式我无法接受,我工资太低,你们做的事情不够酷,你们做的事情不赚钱,你们水平不够好。其实...

JAVA程序员述职报告

Android程序员学WEB前端(1)-HTML(1)-标准结构常用标签-Sublime

http://blog.csdn.net/iwanghang/article/details/76522043

C和C++程序员面试秘笈

  • 6天前 17:30
  • 48.56MB
  • 下载

Android程序员学PHP开发(21)-使用foreach、list、while、each遍历数组-PhpStorm

转载请注明出处:http://blog.csdn.net/iwanghang/ 觉得博文有用,请点赞,请评论,请关注,谢谢!~ foreach: 数组的遍历方法有很多,在其他语言里,下标连续的数组...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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