前谷歌技术主管亲述:程序员请避开这几大雷区

新闻
软件工程师的技能发展都会经历一个自然的过程——经验从无到有,最后变成老手。而一旦到了经验丰富的阶段,他们对代码就不那么感兴趣了。本文将指出工程师们可能表现出的一些抑制其发展的特征。

软件工程师的技能发展都会经历一个自然的过程——经验从无到有,最后变成老手。而一旦到了经验丰富的阶段,他们对代码就不那么感兴趣了。恰恰相反,他们会把更多的精力放在文件设计和代码重构上。

[[271043]]

奇怪的是,不管任职于哪家公司,大多数经验丰富的工程师都会表现出同样的特点。他们缺乏对代码的关注,和其他工程师相比,他们写代码的速度较慢。这是因为和仅仅编写代码相比,他们会将更多的时间花在设计上面。

从一个新手到经验丰富,这个转变过程不是一蹴而就的。但一般而言,这些工程师会用几年甚至几十年的时间,逐渐成为领域内资历很高的人。

他们似乎在每个公司都是一样的——不断地处理新出现的需求,进行不必要的繁忙工作——这无疑会让他们感到沮丧。本文将指出工程师们可能表现出的一些抑制其发展的特征。

1. 在代码重构上浪费时间

@techleadhd作为目前在世的经验最丰富的工程师之一,在推特上透露了他关于编写代码的真实想法。

他显然不相信编写代码的意义。相反,他暗示称删除和重构代码是有价值的。

但这项工作并不是软件清理,而是做软件工程。

这就意味着工程师需要设计代码,而不是维护代码。维护代码是其他人的工作,兴许实习生就能做到。

软件工程师们应该花时间对那些陈旧低效的代码进行编程,而不是试图改进旧的基础结构。只要工作正常运作,就还可以用尚有不足的代码。然而,不少经验丰富的工程师似乎认为维护旧代码具有很重要的意义。

2. 关注整体情况而不是代码

值得明确的一点是,整体情况和业务方面的事情并不重要,重要的是代码!

经验丰富的软件工程师有一个坏习惯,就是把注意力集中在整体情况而不是代码本身。他们喜欢提出这样的问题,比如“这个项目将对谁产生影响”“最终用户将如何与代码交互”以及“工程师将如何维护代码”。

他们花费很多时间试图去了解项目的范围以及它对于公司的影响。有时,他们甚至会用他们认为的“更好的解决方案”来挑战领导阶层。那么,当他们专注于诸如“影响”和“优先次序”之类的琐事时,他们如何抽出时间来完成所有代码?

把所有的时间都花在会议、巩固、度量跟踪和代码审查上,会导致代码编写不再纯粹。

优秀的程序员不应该质疑他们正在做的事情。相反,无论是什么请求,他们都应该低下头来编码。在任何时候,企业都确切清楚什么样的行为将会对公司产生影响。作为程序员的工作职责,就是做好本职工作,而不是弄清楚他们做的事情是否值得,或者是否符合公司的战略。

希望经验丰富的工程师们记住:你是程序员,而不是领导者。

3. 总是想要一个设计文档

出于某种原因,经验丰富的软件工程师们总是想要一个设计文档。其实,在不考虑设计文档的情况下,无论项目规格多大,直接开始编写都要快得多。

人们不会用一个稍微不同的对象或任何东西去重复功能。那么,为什么经验丰富的软件工程师偏要如此在意呢?

最后,如果不需要花时间考虑设计文档,工程师很可能将以快十倍的速度编写代码。

4. 不喜欢“复杂性”和“设计过度的工程”

[[271044]]

在某种程度上,有些资历颇深的工程师不再愿意深思其他人的代码。

因此,当创建一个模块时,他往往把在学校学到的所有知识都融合到一个面向对象记忆体中,并通常声称这是过度设计的代码。

其实他们只是不想深思别人的杰作。

花时间去理解如何从对象B中得到对象A,然后调用函数C,调用函数D,有时选项F和选项G从配置文件E提取,配置文件E用函数F从数据库G中来解析数据,然后将日志存储在Hadoop、 CouchDB和S3中,这会很困难。

人们开始抱怨,说代码太简单,或者设计太复杂。懒惰使得精心设计的代码很容易停产。

5. 他们都被困在未来

事实上,我们现在所了解的框架往往是一生中所需要了解的唯一框架。

然而,经验丰富的工程师似乎花费了大量的时间去学习新的框架和语言,最起码去研究新的设计原则,但这往往并非是必须要做的事情——很多事情并非是越多越好的。

[[271045]]

事实上,从这一点来考虑的话,经验丰富的软件工程师可能正是阻碍社会发展的因素之一。

随着对代码重构、设计文档和学习所提出的源源不断的需求,他们不断地推进着软件的迭代。我们甚至可以这么想:如果没有那些经验过度丰富的工程师,现在说不定已经出现比我们更智能的飞行汽车和机器人了!

责任编辑:赵宁宁 来源: 读芯术
相关推荐

2019-08-14 17:20:40

程序员人生第一份工作Google

2017-10-04 12:34:12

Go语言程序员

2019-06-05 07:16:17

2017-06-06 10:18:35

技术主管微服务

2015-02-12 09:29:48

2016-05-10 10:31:45

2011-06-02 11:26:24

程序员

2015-01-04 14:18:21

程序员

2019-12-26 16:45:09

程序员人生第一份工作C语言

2020-12-21 06:15:15

程序员互联网年龄

2011-04-26 10:00:23

C语言程序员

2019-08-30 10:51:21

2012-09-10 09:16:54

2015-02-12 09:48:09

程序员

2009-06-22 09:06:57

程序员技术升级

2011-07-19 13:27:35

2015-10-26 10:49:07

程序员

2015-10-19 09:05:01

程序员成长

2015-10-28 10:07:22

程序员薪水

2013-06-09 09:56:35

点赞
收藏

51CTO技术栈公众号