如何学习编程
人们经常问我一个问题:“我如何成为一名程序员?“或者"我如何学习编程?“根据个人情况和学习方式,这个问题有很多可能的答案。既然人们如此频繁地问我这个问题,我想我最好写一篇文章来讨论它。
寻找最佳方法
无论使用什么方法,我在学习编程时一直遵循的一个有用规则是:始终问自己"完成这个任务的最佳方式是什么?“或"完成这个任务的正确方式是什么?“也就是说,在编程中,你可以采取许多不同的路径来完成你的任务。但通常,只有其中一种是推荐的方式,要么是按照你所用编程语言中最现代的方式,要么是程序员社区基于经验达成共识的最佳实践。
通常,你可以通过阅读正在学习的编程语言的文档,或通过Google或Stack Overflow在线搜索最佳实践来找到这些信息。如果找不到答案,可以在论坛、邮件列表或Stack Overflow上提问。直到今天,当我接到需要学习未知知识的任务时,我仍然会做所有这些事情。
这样做的好处是,你不仅仅是学习编程,而是学习成为一名优秀的程序员。同时,它迫使你真正深入理解你正在使用的工具和语言。如果你在过程中持续这样做,最终你会对你正在使用的系统形成良好、深入的理解,同时保持足够的实用性来维持自己的兴趣。
当然,你必须确保在这样做时真正理解你阅读的所有内容。这可能意味着深入研究更多文档,然后是更多文档,直到你理解所有使用的单词和符号。这没关系!这正是这个系统能够发挥作用的重要原因——你对你正在使用的符号和概念获得了真实、深入的理解。
需要明确的是,当你刚开始学习编程并面临具有挑战性的任务时,用任何你能想到的老方法完成它是可以的。你正在学习基础知识,而不是最佳实践。这条建议适用于你已经克服了学习如何完成任何事情的入门阶段。对于一个纯粹为了学习而做的项目,最重要的部分是你学到了你打算学习的东西。但一旦你掌握了这一点,就要深入钻研,尝试看看你是否以最佳方式完成了事情。
大学教育
大学中与编程相关的最常教授的学科被称为"计算机科学”。我说它与编程相关,是因为在大多数计算机科学课程中学到的东西很少会最终在作为专业工作程序员的日常生活中真正有用。这并不总是正确的——在某些领域,计算机科学非常有用。但总的来说,我们称之为"软件工程"或"开发"的领域与大学所涵盖的"计算机科学"是不同的。
通常,大学涵盖的计算机科学基础知识非常有用。我上过大学并学习计算机科学,我前两年的学习对我非常有用,尤其是最初的几门课程。我在软件开发的一些基本概念上打下了良好的基础。
然而,我当时没有意识到的是,计算机科学只是部分研究编程。另一部分是研究算法。算法研究通常涉及学习最高效的做事方式。也就是说,找出如何使用最少的步骤或最少的内存来完成诸如对整数列表排序之类的任务。有些问题除非你知道正确的算法,否则计算机根本无法解决,偶尔你会在编程中遇到需要这些知识的问题。所以它确实有一些用处。但解决这些算法问题并不是你将花费大部分时间做的事情。
即使是那些提供"软件工程"课程的大学,它们也很少能提供真实世界的完整体验。原因是大多数课程最多只持续几个月,最多只能让你与几个人合作,在一个几千行代码的代码库上工作。在现实世界中,你将与大量人员在一个将持续数年、至少有数万行代码的代码库上工作。然而,这些软件工程课程仍然比什么都没有要好得多。
所有这一切说,有一些大学确实培养出了优秀的程序员,无论是通过计算机科学课程还是软件工程课程。通过上大学课程学习编程总是有一定价值的。至少,上大学提供了一种结构和纪律,鼓励你完成课程。
自学
与大学培训相反的是,许多程序员是自学的。他们在网上阅读一些文档,摆弄东西,以某种方式让这些东西工作,最终通过许多痛苦、艰难的经验成为有能力的程序员。
我学习编程的很多方式就是这样。对我来说最重要的事情是有一个我想要完成的任务。你看,编程是一种工具,它本身不是目的。它是一个你用来完成其他事情的系统。所以你必须有一些你想要完成的事情。有时你必须自己编造那个任务。例如,我的一个朋友有一个非常简单的游戏的想法。所以有一个夏天,我花了几个星期学习Java,以便我能编写那个游戏。我已经从我的大学课程中了解了另一种语言C的编程基础知识。所以我对编程并不完全陌生,这对我帮助很大。
我所做的(也是我建议大多数想学习某种语言的人做的)就是浏览语言创建者提供的官方教程。对我来说,这是一个旧版本的Java教程。几乎每种语言都有这样的官方教程,或者至少推荐一些你可以学习的网站。通常你只需要在Google中搜索你想学习的语言名称,后面加上"教程"这个词,你就能找到你想要的东西。或者去你想学习的语言的主要网站,查看他们的"入门"链接。
如果你完全不知道如何编程,根据你对计算机的经验水平,你可能需要先学习一些其他东西。你可能需要学习一点计算机工作原理,如何编辑文本文件,以及如何通过命令行运行程序(因为这通常是你运行第一个程序的方式)。不过,现在通过使用基于网络的代码编辑器,很多这些都被简化了,你可以在网络浏览器中直接编写代码并运行它。要找到其中一个,只需在Google中搜索你的语言名称,后面加上"web editor”(不带引号)。
一旦你学习了某种语言的教程,有很多方法可以自学编程。Google和Stack Overflow绝对是你的朋友,你所用语言的官方文档也是。我自学时经常做的是,在语言的官方文档中搜索与我试图做的事情相关的单词,然后阅读这些文档来理解我想要完成什么。但这里的关键是,正如我上面指出的,你必须真正理解。如果你对编程非常非常新,有时只是复制粘贴一些代码而不理解它的作用是可以的。但通常这会很快让你陷入困境,即使是在你自己的理解方面。你会发现某些东西不起作用,而你完全不知道为什么。
事实上,不理解为什么某些东西坏了是自学编程最令人沮丧的部分之一。我猜这是大多数人放弃的地方。某些东西不起作用,系统输出一些完全神秘的错误信息,而他们不知道如何修复它。这总是,总是因为程序员没有理解编程语言的某些方面,他们正在使用的工具,或者错误信息中的单词含义。当你复制粘贴了某些东西而没有完全理解你复制的代码中的每个单词和符号时,这种情况最常发生。
是的,逐一学习每个单词和符号的真正含义可能看起来工作量很大,但这就是你学习编程的方式。程序员对社会有价值不仅仅是因为他们知道从哪里以及如何从Stack Overflow复制粘贴东西。他们有价值是因为他们学习并理解了某些概念,以及如何应用它们。通过这样做,你实际上是在增加你作为程序员的价值。
然而,在没有任何帮助的情况下尝试完成这个过程通常仍然非常令人沮丧。希望如果你正在这样做,当你完全卡住时,有你可以联系的人,他们可以帮助回答你的问题。我没有人可以求助,有时这非常艰难,我会花30个小时盯着一段代码,抓耳挠腮试图理解为什么这该死的东西不起作用。所以如果你有可以交谈的人,这通常比试图自己解决要好,尤其是当你刚刚开始时。有时当你对编程完全陌生时,阅读某个东西的所有文档可能会让人不知所措。有一个指导者,或者至少一个帮手,会很有帮助。
编程训练营
介于大学培训和自学之间的是"编程训练营”,这是过去几年出现的一种现象,组织声称可以在X周或Y个月内教会人们编程。通常,这些项目实际上提供了比大学更好、更实用的教育,尽管其中一些没有给你大学培训会给你的理论深度。也就是说,你不会学到像从一些更正式的培训中可能学到的那么多编程背后的理论(特别是如何良好编程的基础知识)。
我要说的是:如果一个项目承诺在不到一个月的时间内教会你编程,那很可能是垃圾。在那段时间里,你也许可以学习一些Web开发的基础知识,但你永远不可能通过仅仅四周的经验学会成为一名专业程序员。据我从各种训练营的结果观察,获得作为优秀程序员的基本技能是一个至少需要数月的过程。你可能在几周的课程中获得足够的基础知识,然后可以继续自学其余部分,但一个月的编程不会把你变成专业开发人员。
所有这些可能听起来好像我对训练营相当消极,好像成为"真正程序员"的唯一方式就是忍受自学的痛苦。然而,这与事实相去甚远。事实上,我见过从训练营出来的优秀产品。就个人而言,我见过的最好的编程学校现在可能被称为"训练营”,那就是The Tech Academy。他们做得很好,把不知道如何编程的人变成程序员,当人们问我如何编程如果他们不想只是自学时,我总是推荐它。可能还有很多其他不错的训练营。
如果今天我评估一个训练营,我会找出他们有多少毕业生找到了作为专业程序员的好工作,并尝试找到其中一些毕业生,询问他们接受的培训与他们实际日常工作有多大相关性。
经验
一旦你通过大学、自学或编程训练营学会了编程的基础知识,在职业发展方面你能做的最重要的事情之一就是选择一些好的初步经验,帮助你成长为软件开发人员。
实习
如果你是一名大学生,我强烈建议你利用许多软件公司提供的暑期实习。这是获得在真实软件公司工作的低风险体验的最佳方式。大多数公司实际上会付钱给你,这也是毕业后被该公司雇用的最简单方式。因为他们已经对你有经验,招聘过程会容易得多。
开源
如果有某个你真正想参与的开源项目,试着看看他们需要什么,然后就去工作。很多时候,开源项目有一个为新来者提供的可用任务列表,你可以挑选一些任务并开始工作。这样做的好处是通常没有截止日期,而且通常有一个非常支持性的志愿者社区,他们可以在邮件列表、聊天室等地方回答你的问题。由于大多数开源项目都进行称为"代码审查"的过程,你还会从更高级的工程师那里获得关于你代码的反馈,这也会帮助你成长为程序员。除此之外,在开源中工作提供了你可以向任何雇主展示的工作证据。此外,公司通常喜欢在你的简历上看到开源参与,因为它表明你对编程感兴趣并有热情。
导师指导
当你接受第一份程序员工作时,考虑它将为你提供的成为更好程序员的机会。公司是否有更有经验的软件工程师可以帮助你成长,还是完全由几乎没有专业经验的新大学毕业生组成?公司是否进行代码审查,即你的每个更改都由更高级的工程师审查以帮助你在编程方面变得更好?
也许最重要的是,当你接受一份工作时,确保它是一个关心软件最佳实践的公司。这在软件公司——即其主要产品是软件的公司——比其他公司更常见。你更有可能在稍微成熟一点的公司,或者至少不是在可怕截止日期压力下即将倒闭的公司(比如资金即将耗尽的初创公司)获得这种体验。
我并不是说你应该仅仅因为他们可能不是完美的工作公司就拒绝你唯一的offer。但请记住,如果你在寻找作为程序员的职业和技能成长,你不会通过为讨厌你的产品但不知何故被迫使用它的用户在紧迫的截止日期下编写糟糕代码来获得它。
阅读
网上有很多关于软件最佳实践的内容。也有很多好书。值得在线阅读各种软件最佳实践,特别是当它们直接与你实际试图解决的某些实际问题相关时。继续阅读书籍、博客、网站等是保持更新的好方法,有时即使它们不直接实用。例如,偶尔我会去阅读一些新的编程语言或某些CPU功能,不是因为它与我在做的事情有任何关系,而是因为它似乎是我作为程序员应该知道的好而有用的信息。
总结
这就是当人们问我如何编程时我通常给出的建议基础。可能还有其他需要知道的东西,尤其是我在《为什么程序员很烂》中涵盖的内容。当然,以上所有内容只是一个需要数月或数年才能真正熟练掌握的过程的总结。但希望这能帮助你学习编程,或提供一个当别人问你同样问题时你可以发送给他们的资源!
-Max