我是如何学习计算机编程的
fmms 13年前
<h1 class="entry-title">我是如何学习计算机编程的</h1> <div id="lang-guess"> <p id="page-note">本文是从 <a href="/misc/goto?guid=4958193848199646142">How I Learned to Program Computers</a> 这篇文章翻译而来。 </p> </div> <p>我在很小年纪的时候就开始学习编程,我学习编程的方法是创建大量的不同的网站。下面列出的是我创建的主要的网站,其中最早的一个是我11岁时开发的。我希望读者能从我这些复述中获得的信息是:如果你想学习编程,<strong>做大量的练习性的项目是非常必要的。</strong></p> <p>学习一种技术最好的方法就是<strong>练习,练习,练习</strong>。所有我知道的最优秀的程序员都深深的享受编程——编程是一件让他们干起来无由的高兴的事情。也因此他们<strong>大量的编程</strong>。经常,那是一种不健康的废寝忘食。学习如何编程——以及如何编<em>好</em>程——并不需要你具有超人的能力。你只需要去按照自己的意愿<strong>动手去做</strong>,做出点什么东西。</p> <p>做什么东西并不重要,重要的是你找到东西<em>动手去做</em>。我所认识的那些优秀的程序员,他们都有各自不同的最初学习编程的动机。有些人学习编程是为了<strong>开发动画游戏</strong>。有些人是为了解决他们在使用计算机时遇到的问题,或<strong>让工作更有效率</strong>。有些人是为了<strong>开发产品</strong>来满足人们的需求。有些人(真正的程序员)学习编程只是他们为了深入了解计算机工作原理的步骤之一 ;他们希望能<strong>搞清楚这种机器</strong>。有些程序员编程只是因为他们享受<strong>解决难题</strong>的挑战。</p> <p>让所有这些“优秀程序员”统一起来的唯一因素就是,他们全因为生活中的某些原因而为编程<strong>着迷</strong>,继而<strong>花大量的时间编程</strong>,做大量的,大量的<strong>用于练习的项目</strong>。</p> <p>那么,我就不再罗嗦了,下面就是我如何学习编程的故事:</p> <h3>我的第一个网站</h3> <p><img title="作者小时候的照片" border="0" alt="作者小时候的照片" src="https://simg.open-open.com/show/6d96500a68f908084a63436894b5b4fb.jpg" width="250" height="185" /></p> <p>在我大概十一二岁的时候,我感到需要给自己做一个网站。我已经记不清<strong>为什么</strong>需要一个网站了,只记得那样就开始做了。于是我就在网上搜索关于网页、Web浏览器、HTML如何工作的信息。很多的信息我发现都已经过时了,有些明显是错误的或给了错误的向导(例如为IE 浏览器和Netscape浏览器分别做网站),但过程是非常的有趣的,我学到了很多新东西。</p> <p>尽管在网上搜到了很多粗制滥造的的信息,我还是想办法做了一个简单的网站,我叫它“Feross的网站”。开发它,我使用的是微软的Frontpage,那是一个非常棒的<a href="/misc/goto?guid=4958193848941593054" target="_blank">所见即所得</a>的HTML编辑器。我使用很常见的语法,例如粗体,斜体等对网站做修改,在编辑器里即时查看这些HTML标记能达到的效果。这是很有效的学习方式。</p> <p>下面是我的第一个网站的截屏。这个网站已经不存在了。</p> <p><img class="aligncenter size-large wp-image-3598" title="我的第一个网站" alt="我的第一个网站" src="http://www.aqee.net/wordpress/wp-content/uploads/2011/10/feross-website-1.png" width="600" height="527" /></p> <p>你从上面的图片上看不出来,这个网站上的每个元素都在动,闪烁的动画,还能出声。我在网站的每个页面上都放置了不同的MIDI格式的歌曲。而且都是自动播放,你没有办法让它们停下来,除非把电脑消音。哈,这就是当年流行的网站设计风格。 <img class="wp-smiley" alt=":D" src="https://simg.open-open.com/show/c7597052fe2b16db307d6bd14e7b8c6b.gif" /> </p> <p>等再长了几年岁数后,我们重新设计这个网站,让它变的漂亮些。我使用了在网上发现的一些免费的网站模板,用微软的画图工具修改了一些图片。</p> <p><img class="aligncenter size-large wp-image-3599" title="修改后的第一个网站" alt="修改后的第一个网站" src="http://www.aqee.net/wordpress/wp-content/uploads/2011/10/feross-website-2.png" width="600" height="409" /></p> <p>经管我大量的依赖于模板,但这不失为一个学习HTML和Web浏览器的好方法。“Feross的网站”除了用来收集我小时候的一些视频外没有其它用处,所以不久后我就对它失去了兴趣。</p> <h3>我的第一个真正的</h3> <p>当我9年级(14岁)时,我和我的朋友都非常着迷与观看像<a href="/misc/goto?guid=4958193849676222693" target="_blank">Newgrounds</a> 和 <a href="/misc/goto?guid=4958193850407435905" target="_blank">eBaumsWorld</a>这样的网站上的flash视频和动画(这是2005年之前,还没有油Tube)。我在这种网站上花了大量的时间,所以我知道所有最好的视频和游戏。我想,如果做一个网站来收集这些在网上发现的我喜欢的flash动画、视频、游戏,会是一件很酷的事情。这就是我做出FreeTheFlash网站的初衷。它是这个样子的:</p> <p><img class="aligncenter size-large wp-image-3600" title="freetheflash-1" alt="" src="http://www.aqee.net/wordpress/wp-content/uploads/2011/10/freetheflash-1.png" width="600" height="642" /></p> <p>我从开发“Feross的网站”的过程中学到了很多HTML知识,这次我使用了Macromedia 公司(现在的Adobe公司)的Dreamweaver编辑器,这个东西能让我在网站里重复的页面使用同一个模板。</p> <p>一段时间后,我意识到,我应该让网站<em>动起来</em>,听说是应该使用一种叫做PHP的编程语言来做网站,而不是只使用静态的HTML。于是,我买了花了20美元从Amazon买了一本书,叫做《PHP and MySQL for Dynamic Websites》,使用PHP和MySQL对网站进行了重新设计。我还给它进行了新的美化:</p> <p><img class="aligncenter size-large wp-image-3601" title="PHP&MYSQL动态网站" alt="PHP&MYSQL动态网站" src="http://www.aqee.net/wordpress/wp-content/uploads/2011/10/freetheflash-2-600x612.png" width="600" height="612" /></p> <p>在高中时期我对这个FreeTheFlash 网站的开发持续了2年。它对于我的第一次尝试做一个“真正”的网站来说是相当成功的——在2006年,它获得了60万人/次访问,页面浏览量达3百万。 FreeTheFlash 让我知道了做出一个产品、让它杰出、看大量的人使用它,是一件多么自豪的事情。它让我想做出更大的网站。</p> <h3>我的第二个网站</h3> <p>在中学,我在上计算机课程时做了大量的笔记。于是,在11年级时,我觉得应该把这些笔记放到网上,让那些不喜欢看课本的学生使用。我做了一个网站,叫做StudyNotes,使用的是PHP和一个叫做Joomla的内容管理系统。我也尝试过使用Drupal,但发现它太复杂了。</p> <p><img class="aligncenter size-large wp-image-3597" title="学习笔记网站" alt="学习笔记网站" src="http://www.aqee.net/wordpress/wp-content/uploads/2011/10/ap-study-notes-600x352.png" width="600" height="352" /></p> <p>同年,我为我的学校Key俱乐部分部做了一个网站,如今也不用了。</p> <p>这段时间,我花了大量的时间泡在<a href="/misc/goto?guid=4958193851144814861" target="_blank">WebmasterWorld</a>里,这是一个论坛,主要关于网站站长和SEO专家推测Google算法,讨论AdSense技巧,调试网站问题等。</p> <h3>大量的学习和阅读</h3> <p>等我进入了斯坦福大学后,我学习了大量的计算机课程,诸如<a href="/misc/goto?guid=4958193851887294215" target="_blank">CS106X</a> 和 <a href="/misc/goto?guid=4958193852627115151" target="_blank">CS107</a>,我还超前学习了部分<a href="/misc/goto?guid=4958193853358954348"> CS106 </a>课程。</p> <p>所有的课余时间我几乎都在阅读关于设计、编程、浏览器和JavaScript等方面的资料。一般每天4-5个小时。</p> <p>如果你要问我都读什么?乱七八糟的。但大部分都是我敬仰的设计师和程序员写的博客。你可以从这篇博客的右侧看到我列出的部分博客链接。</p> <h3>关键一击</h3> <p>之后,在2010年夏天,当我在非死book实习时,因为跟一个朋友打赌,我开发了<a href="/misc/goto?guid=4958193854093501270" target="_blank">油Tube Instant</a>,它是一个用来实时搜索油Tube视频的网站。这个网站在建成之后的10天里获得了1百万用户的访问量,油Tube的CEO甚至给我发消息说提供一个职位给我,你可以从<a href="/misc/goto?guid=4958193854828186819">这里</a>看到这些媒体的躁动。</p> <p>我知道油Tube Instant的成功归功于当前的好时机和一点幸运。我想,我们很多人不知道自己能做出什么。</p> <p><img class="aligncenter size-full wp-image-3603" title="油Tube-instant-job" alt="油Tube Instant" src="http://www.aqee.net/wordpress/wp-content/uploads/2011/10/油Tube-instant-job.png" width="540" height="517" /></p> <h3>继续前行</h3> <p>我注意到很多人使用油Tube Instant来听音乐视频,这让我想到了另外一种使用油Tube API的好方法。于是,我的朋友Jake Becker 和我在2011年的头3个月里开发了<a href="/misc/goto?guid=4958193855566807129" target="_blank">Instant.fm</a>,它能让你轻松的向朋友分享音乐播放列表。通过这个项目我们都学到了很多新的东西。</p> <p><img class="aligncenter size-large wp-image-3605" title="Instant FM" alt="Instant FM" src="http://www.aqee.net/wordpress/wp-content/uploads/2011/10/InstantFM-600x676.jpg" width="600" height="676" /></p> <p>在这个工程中我掌握的技术:</p> <ul> <li><a href="/misc/goto?guid=4958183308549259819" target="_blank">jQuery</a></li> <li>CSS (和 <a href="/misc/goto?guid=4958193856985135572" target="_blank">Modernizr</a> 以及 <a href="/misc/goto?guid=4958193857725582753" target="_blank">YepNope</a>,用来解决跨浏览器问题的)</li> <li><a href="/misc/goto?guid=4958187574087660729" target="_blank">Python</a></li> <li><a href="/misc/goto?guid=4958186851423143926" target="_blank">Tornado</a> (web framework/server)</li> <li><a href="/misc/goto?guid=4958183577944756424" target="_blank">Git</a> (版本控制) & <a href="/misc/goto?guid=4958183584851817768" target="_blank">GitHub</a></li> <li><a href="/misc/goto?guid=4958193861156639538" target="_blank">Last.fm API</a></li> <li><a href="/misc/goto?guid=4958193861905807648" target="_blank">油Tube API</a></li> <li>团队合作</li> </ul> <p>以及其它一些我们学会使用的东西:</p> <ul> <li><a href="/misc/goto?guid=4958187734501359851" target="_blank">Nginx</a> (web server)</li> <li><a href="/misc/goto?guid=4958193863311418805" target="_blank">Supervisor</a> (to daemonize Tornado)</li> <li><a href="/misc/goto?guid=4958193864039269840" target="_blank">SQLAlchemy</a> (ORM)</li> <li><a href="/misc/goto?guid=4958193864779301928" target="_blank">Apache Ant</a> (to build and deploy the site after a push)</li> </ul> <h3>动手去做!</h3> <p>我把从11岁就开始做的东西都不厌其烦的曝出来,目的就是要说,如果你想学习编程,你需要<strong>动手去做东西</strong>!现在就去。不要找任何借口。</p> <p>做东西是最好的学习方法。</p> <p>从头到尾读一遍编程语言书籍是一件很无聊的事,读到一半你就读不下去了。但,如果你<strong>想做一个项目</strong>,你在做的过程中会知道你该学习哪些知识,这是认识和掌握知识更有效的途径。</p> <h3>计算机课程</h3> <p>大学里的计算机课程是学习编程的另外一种十分有效的方法。大多数好的计算机课程都十分强调学习计算机科学领域里的重要概念和范式,而不是教你某个特定的语言。这能让那些从来没有接受过正规教育的人在自学时开阔眼界。</p> <p>记得在斯坦福大学上第一堂计算机课程时(那是教授C++的课程),我在想“怎么可能变量前不带$符号呢?”当时我只使用过PHP! <img class="wp-smiley" alt=":)" src="https://simg.open-open.com/show/b2984729c3b6cdc07508b88b5c0a4d1e.gif" /> 我用了好长一段时间才改掉在变量前加$符号的习惯!</p> <h3>在软件公司工作</h3> <p>另外一个提高编程水平的方法就是到软件公司实习,比如非死book或Quora,最近的两个夏天我就是在这些公司里度过的。你会从那些优秀的人那里学会如何更好的编程,如何阅读和理解他人的代码,如何在大项目中进行团队合作。</p> <p>还是那句话——比什么方法都管用——学习编程最好的方法就是<strong>做项目练习</strong>。我是不是重复这句话无数次了? <img class="wp-smiley" alt=":)" src="https://simg.open-open.com/show/b2984729c3b6cdc07508b88b5c0a4d1e.gif" /> </p> <h2>如何学会编程:</h2> <ul> <li>做练习性项目。</li> <li>看编程书籍。</li> <li>做项目练习。</li> <li>上计算机课程。</li> <li>做练习性项目。</li> <li>读编程类博客。</li> <li>做项目练习。</li> </ul> <p>这就是我能给出的最好的建议。</p> <p>祝编程愉快!<br /> <br /> 本文来自:<a href="/misc/goto?guid=4958193865515479521" target="_blank">http://www.aqee.net/how-i-learned-to-program-computers/</a></p>