英文原文:A Cautionary Tale of Learning to Code
这是一个真实的故事,关于我自己的。一个理智的生命个体是怎么一步步走向疯狂?
我穿着西装,坐在办公室里,脑子里有一个模糊的创业想法。然后,我决定学习编程。我曾经无意中听到过几个人在那吹牛说自己怎么使用一种叫 Ruby 的语言轻松实现自动办公。我想“呵,Ruby”。我回到家,谷歌 Ruby。15 秒之后,我随机选择了一个 Ruby 教程,开始学习。
一周以后,我参加人生中的第一次黑客聚会。在场的每个人都在讨论什么 Scala,Clojure,Go。我想,他们学得还真是多。转身我就借了三本O'reilly 的书,每本书看了大概 50 页。
什么?你问我为什么没有完整地看完一本书?那还不是因为每本书开始的时候简单易懂,然后就开始做假设,假设你具备这个知识,假设你会使用那种工具,可是这些我都不会好吗?
我的一个朋友告诉我应该学 Emacs,并且给了我他的配置文件。我又花了几个小时学习基本的 Lisp 语法,以便我能自己设置配置文件。
然后一个人从我身边经过,看见我正在使用 Emacs,就问“你怎么还在用 Emacs(表情自行脑补),你不知道 Vim 更好吗?”我想“呵,Vim”,于是我开始背诵 Vim 成堆的键盘快捷键。
工程师们经常讨论这样一个话题,文本编辑器哪家强?并且,工程师们将这看成是一场宗教战争——评判的标准不在于客观的准则,而在于历史分歧。
那时候,我认为如果我打字越快,我编程的速度也会越快。所以我抛弃了传统的键盘布局,用上了程序员必备的 Dvorak 键盘布局(就像下面这样)。客观上来说,对程序员而言,这是最高效的一种键盘布局。
看着上面的键盘布局,你能告诉我有多少字母键,数字键,特殊字符键的位置没有变动吗?答案是个位数。
等我能够成功启动 Linux,一分钟能够敲出十个单词的时候,我开始通过看书和 Udacity 的课程学习 Python。
经过七个月的艰苦奋战,我得到了第一份软件工程师的工作。
CTO 面试我的时候,我告诉他所有我学过的工具和我正在使用的高大上的配置文件。CTO 礼貌地听我说着,时不时点点头。等我吹嘘完自己渊博的知识之后,他看了我一眼,然后说“其实,大部分事情都有很多解决的办法,但是只有其中的极小一部分是有意义的”。
四年以前,我所在的公司决定使用 Ruby on Rails 构建他们的产品。对于语言的选择,所有的工程师都没有意见,现在,他们的许多原始代码还在工作。所有的工程师都用 MacBook,因为 MacBook 不仅可靠,并且和他们在产品中使用的 Ubuntu Linux 服务器非常类似。这里的工程师不讨 Vim 和 Emacs 哪家强,每个人使用的文本编辑器都是 RubyMine,这是一个强大的集成开发环境,默认配置非常好用。这里的每个工程师使用的工具完全一致,意味着每个人可以随便挑选自己的座位,然后立马和左边或右边的同事开始结对编程,而不需要纠结开发环境的配置问题。使用完全相同的配置能极大地方便两个开发者之间的合作。
虽然我不会 Ruby on Rails,公司也觉得我能胜任工作。因为我会 Python 和 Django,并且赢得了黑客马拉松的比赛,公司认为这些可以说明问题。
最开始的几周真是艰难,这种艰难不仅仅来自于我来到一个新的团队,使用一种新的语言,新的框架和新的代码库,而是因为我发现身边的人都是以一种自虐的态度在学习编程。
我独自在图书馆、咖啡厅坐了几个月,每天就是盲目的通过命令行安装各种工具,调试 Linux 驱动,解决一些细枝末节的问题,比如说括号不匹配。我涉足每一个能想到的在线课程,报了无数的 MOOC 课程。我认为实际上我什么都没学到,直到在某个月的考核中,我上升至第五位。这些经历给我的印象是,编程是一场你永远无法取得胜利的战斗。我开始明白那些看起来正常的程序员他们的过往实际上是那么灰暗,他们经历过太多,又压抑得太久,不得不说,学习编程简直就是一个反社会的活儿。
辞掉上一份工作的第一个周末,我上传了这张自拍。那天我起了个大早,穿了件体面的西装,穿西装是为了提醒自己:我可是要去学习编程的人。Facebook 的标语“我的新办公室——餐桌上。我每天过着朝 8 晚 6 的生活,只有在必须要休息的时候才休息”。在生活中,我学程序员说话,像他们一样思考,现在,我已经习惯了这个词。
我的同事几乎从没遇到过语法错误,因为他们的 IDE 替他们解决这个问题。而当他们遇到一个错误信息,如果在几分钟内不能解决问题,他们就会给其他同事发送一条即时消息,请求其他人的帮助。他们会随意跳到别人的桌旁,然后开始结对编程。这里的程序员不会太自我,也不自诩为精英。他们也不认为编程是一件痛苦的事。有的只是成年朋友之间的建设性的对话。
一个团队中的成员使用的工具是高度一致的。在 Passion Project 和黑客马拉松中,开发者可能会使用新的 JavaScript 框架,比如说 Angular.js。而在一个真正的团队里,成员把精力主要放在使用现有的技术提升产品之上。从这个角度来说,他们是保守的。
在 ThoughtBot 你也会看到类似的情况,在 ThoughtBot 中,每个人都坚持使用一个小且高效的工具集(Rails,Vim,Postgres 和 Redis)。因为工具集小,所以工程师容易成为该领域专家,又因为每个人使用的工具集都是一样的,所以相互之间进行互操作就变得很容易。
所以真正的问题是,如果高效的团队在使用一个小且固定的工具集的时候最高效,那么是不是人们在学习编程的时候使用一个小且固定的工具集是最好的。那些在线编程课程和编程训练营显然是这么想的。
但是作为一个个体,可以选择的工具那么多,真的很难决定到底该怎么选。我知道这一点是因为我经历过。一个好的程序员的技能集合可以用T形来表示——涉猎的领域很多,但是真正擅长的领域不多。但是,经过经年累月的积累,T形将会慢慢变成下划线形。
我遇到过许多学习编程的人,上来就想什么都学,什么都会,最终,他们都失败了,放弃了他们成为一个程序员的梦想。我不想这种情况也发生在你的身上。
你需要专注更多方面
事不宜迟,下面给出一些新手容易犯的大错误:
如果非得用一个词来总结我的建议,我会说:专注。
我问你,你会用专注这个词来描述你的编程学习计划吗?如果你认为你的计划够专注,好,你现在可以停止阅读,回到你的计划开始学习,因为我不想说任何可能导致你失去专注的事情。
如果你还的计划不够专注,那你也有福了——照我说的去做,你也能专注,但是这需要花费你几分钟的时候做几个艰难的决定。等等,你们别走啊!
好的,你还没走。下面就是你需要做出的艰难的决定。
一旦你做出了这些决定,剩下的路就太简单了。你只要保持清醒,不要被周围的新工具所迷惑。一周七天,每天学一点在线课程,哪怕一次只有半小时。相信你今天做出的决定。最后,请记住:只要有耐心,任何能干的人都能成为绝世 coder,当然也包括你。