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