`
lwlsoftware
  • 浏览: 5243 次
  • 性别: Icon_minigender_1
  • 来自: 大连
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

用十年来学编程

阅读更多

用十年来学编程
Peter Norvig

为什么每个人都急不可耐?

走进任何一家书店,你会看见《Teach Yourself Java in 7 Days》(7天Java无师自通)的旁边是一长排看不到尽头的类似书籍,它们要教会你Visual Basic、Windows、Internet等等,而只需要几天甚至几小时。我在Amazon.com上进行了如下搜索
pubdate: after 1992 and title: days and (title: learn or title: teach yourself)
(出版日期:1992年后 and 书名:天 and (书名:学会 or 书名:无师自通))
我一共得到了248个搜索结果。前面的78个是计算机书籍(第79个是《Learn Bengali in 30 days》,30天学会孟加拉语)。我把关键词“days”换成“hours”,得到了非常相似的结果:这次有253本书,头77本是计算机书籍,第78本是《Teach Yourself Grammar and Style in 24 Hours》(24小时学会文法和文体)。头200本书中,有96%是计算机书籍。
结论是,要么是人们非常急于学会计算机,要么就是不知道为什么计算机惊人地简单,比任何东西都容易学会。没有一本书是要在几天里教会人们欣赏贝多芬或者量子物理学,甚至怎样给狗打扮。在《How to Design Programs》这本书里说“Bad programming is easy. Idiots can learn it in 21 days, even if they are dummies.” (坏的程序是很容易的,就算他们是笨蛋白痴都可以在21天内学会。)
让我们来分析一下像《Learn C++ in Three Days》(3天学会C++)这样的题目到底是什么意思:
  • 学会:在3天时间里,你不够时间写一些有意义的程序,并从它们的失败与成功中学习。你不够时间跟一些有经验的程序员一起工作,你不会知道在C++那样的环境中是什么滋味。简而言之,没有足够的时间让你学到很多东西。所以这些书谈论的只是表面上的精通,而非深入的理解。如Alexander Pope(英国诗人、作家,1688-1744)所言,一知半解是危险的(a little learning is a dangerous thing)
  • C++:在3天时间里你可以学会C++的语法(如果你已经会一门类似的语言),但你无法学到多少如何运用这些语法。简而言之,如果你是,比如说一个Basic程序员,你可以学会用C++语法写出Basic风格的程序,但你学不到C++真正的优点(和缺点)。那关键在哪里?Alan Perlis(ACM第一任主&席,图灵奖得主,1922-1990)曾经说过:“如果一门语言不能影响你对编程的想法,那它就不值得去学”。另一种观点是,有时候你不得不学一点C++(更可能是javascript和Flash Flex之类)的皮毛,因为你需要接触现有的工具,用来完成特定的任务。但此时你不是在学习如何编程,你是在学习如何完成任务。
  • 3天:不幸的是,这是不够的,正如下一节所言。

10年学编程

一些研究者(Bloom (1985), Bryan & Harter (1899), Hayes (1989), Simmon & Chase (1973))的研究表明,在许多领域,都需要大约10 年时间才能培养出专业技能,包括国际象棋、作曲、绘画、钢琴、游泳、网球,以及神经心理学和拓扑学的研究。似乎并不存在真正的捷径:即使是莫扎特,他4 岁就显露出音乐天才,在他写出世界级的音乐之前仍然用了超过13年时间。再看另一种音乐类型的披头士,他们似乎是在1964年的Ed Sullivan节目中突然冒头的。但其实他们从1957年就开始表演了,即使他们很早就显示出了巨大的吸引力,他们第一次真正的成功——Sgt. Peppers——也要到1967年才发行。Malcolm Gladwell 研究报告称,把在伯林音乐学院学生一个班的学生按水平分成高中低,然后问他们对音乐练习花了多少工夫:

在这三个小组中的每一个人基本上都是从相同的时间开始练习的(在五岁的时候)。在开始的几年里,每个人都是每周练习2-3个小时。但是在八岁的时候,练习的强度开始显现差异。在这个班中水平最牛的人开始比别人练习得更多——在九岁的时候每周练习6个小时,十二岁的时候,每周8个小时,十四岁的时候每周16个小时,并在成长过程中练习得越来越多,到20岁的时候,其每周练习可超过30个小时。到了20岁,这些优秀者在其生命中练习音乐总共超过 10,000 小时。与之对比,其它人只平均有8,000小时,而未来只能留校当老师的人仅仅是4,000 小时。

所以,这也许需要10,000 小时,并不是十年,但这是一个magic number。Samuel Johnson(英国诗人)认为10 年还是不够的:“任何领域的卓越成就都只能通过一生的努力来获得;稍低一点的代价也换不来。”(Excellence in any department can be attained only by the labor of a lifetime; it is not to be purchased at a lesser price.) 乔叟(Chaucer,英国诗人,1340-1400)也抱怨说:“生命如此短暂,掌握技艺却要如此长久。”(the lyf so short, the craft so long to lerne.)
下面是我在编程这个行当里获得成功的处方:
  • 对编程感兴趣,因为乐趣而去编程。确定始终都能保持足够的乐趣,以致你能够将10年时间投入其中。
  • 跟其他程序员交谈;阅读其他程序。这比任何书籍或训练课程都更重要。
  • 编程。最好的学习是从实践中学习。用更加技术性的语言来讲,“个体在特定领域最高水平的表现不是作为长期的经验的结果而自动获得的,但即使是非常富有经验的个体也可以通过刻意的努力而提高其表现水平。”(p. 366),而且“最有效的学习要求为特定个体制定适当难度的任务,有意义的反馈,以及重复及改正错误的机会。”(p. 20-21)《Cognition in Practice: Mind, Mathematics, and Culture in Everyday Life》(在实践中认知:心智、数学和日常生活的文化)是关于这个观点的一本有趣的参考书。
  • 如果你愿意,在大学里花上4年时间(或者再花几年读研究生)。这能让你获得一些工作的入门资格,还能让你对此领域有更深入的理解,但如果你不喜欢进学校,(作出一点牺牲)你在工作中也同样能获得类似的经验。在任何情况下,单从书本上学习都是不够的。“计算机科学的教育不会让任何人成为内行的程序员,正如研究画笔和颜料不会让任何人成为内行的画家”, Eric Raymond,《The New Hacker’s Dictionary》(新黑客字典)的作者如是说。我曾经雇用过的最优秀的程序员之一仅有高中学历;但他创造出了许多伟大的软件(XEmacs, Mozilla),甚至有讨论他本人的新闻组,而且股票期权让他达到我无法企及的富有程度(译注:指Jamie Zawinski,Xemacs和Netscape的作者)。
  • 跟别的程序员一起完成项目。在一些项目中成为最好的程序员;在其他一些项目中当最差的一个。当你是最好的程序员时,你要测试自己领导项目的能力,并通过你的洞见鼓舞其他人。当你是最差的时候,你学习高手们在做些什么,以及他们不喜欢做什么(因为他们让你帮他们做那些事)。
  • 接手别的程序员完成项目。用心理解别人编写的程序。看看在没有最初的程序员在场的时候理解和修改程序需要些什么。想一想怎样设计你的程序才能让别人接手维护你的程序时更容易一些。
  • 学会至少半打编程语言。包括一门支持类抽象(class abstraction)的语言(如Java或C++),一门支持函数抽象(functional abstraction)的语言(如Lisp或ML),一门支持句法抽象(syntactic abstraction)的语言(如Lisp),一门支持说明性规约(declarative specification)的语言(如Prolog或C++模版),一门支持协程(coroutine)的语言(如Icon或Scheme),以及一门支持并行处理(parallelism)的语言(如Sisal)。
  • 记住在“计算机科学”这个词组里包含“计算机”这个词。了解你的计算机执行一条指令要多长时间,从内存中取一个word要多长时间(包括缓存命中和未命中的情况),从磁盘上读取连续的数据要多长时间,定位到磁盘上的新位置又要多长时间。(答案在这里
  • 尝试参与到一项语言标准化工作中。可以是ANSI C++委员会,也可以是决定自己团队的编码风格到底采用2个空格的缩进还是4个。不论是哪一种,你都可以学到在这门语言中到底人们喜欢些什么,他们有多喜欢,甚至有可能稍微了解为什么他们会有这样的感觉。
  • 拥有尽快从语言标准化工作中抽身的良好判断力。

抱着这些想法,我很怀疑从书上到底能学到多少东西。在我第一个孩子出生前,我读完了所有“怎样……”的书,却仍然感到自己是个茫无头绪的新手。30个月后,我第二个孩子出生的时候,我重新拿起那些书来复习了吗?不。相反,我依靠我自己的经验,结果比专家写的几千页东西更有用更靠得住。

Fred Brooks在他的短文《No Silver Bullets》(没有银弹)中确立了如何发现杰出的软件设计者的三步规划:

  • 尽早系统地识别出最好的设计者群体。
  • 指派一个事业上的导师负责有潜质的对象的发展,小心地帮他保持职业生涯的履历。
  • 让成长中的设计师们有机会互相影响,互相激励。

这实际上是假定了有些人本身就具有成为杰出设计师的必要潜质;要做的只是引导他们前进。Alan Perlis说得更简洁:“每个人都可以被教授如何雕塑;而对米开朗基罗来说,能教给他的倒是怎样能够不去雕塑。杰出的程序员也一样”。

所以尽管去买那些Java书;你很可能会从中找到些用处。但你的生活,或者你作为程序员的真正的专业技术,并不会因此在24小时、24天甚至24个月内发生真正的变化。

分享到:
评论

相关推荐

    十年编程无师自通.txt

    ”这句话用来警示那些只愿意花费少量时间学习编程的人。如果只是通过短期课程学习了一些基本概念,而没有深入理解背后的原理,那么在实际工作中可能会遇到很多困难。真正的编程高手需要对所学知识有深刻的理解,并...

    C#编程代码十年典藏版

    《C#编程代码十年典藏版》集合了十年来C#编程领域的精华代码示例,由知名编程专家王小科倾力编纂。这个压缩包包含了大量的C#代码片段,旨在帮助开发者深入理解和掌握C#语言的核心特性和高级用法。通过对这些代码的...

    Java编程宝典-十年典藏版

    标题提到的是一本关于Java编程的宝典,而且是指明了是十年典藏版,这表明该书包含了过去十年中Java编程的大量知识和经验积累。描述中提到的“高清完整版”表明这本宝典不仅内容全面,而且在视觉呈现上也是高质量的,...

    Visual C++编程宝典(十年典藏版)

    《Visual C++编程宝典(十年典藏版)》是一本集技能、范例、项目和应用为一体的学习手册,书中介绍了应用VisualC++6.0进行程序开发的各种技术、技巧。全书分4篇,共22章内容,其中,第1篇为技能学习篇,主要包括...

    Visual C++编程宝典(十年典藏版) 明日科技 源代码

    《Visual C++编程宝典(十年典藏版)》是一本集技能、范例、项目和应用为一体的学习手册,书中介绍了应用Visual C++ 6.0进行程序开发的各种技术、技巧。全书分4篇,共22章内容,其中,第1篇为技能学习篇,主要包括...

    ASP.NET编程宝典(十年典藏版)》光盘源码1

    《Java Web编程宝典(十年典藏版)》是一本集技能、范例、项目和应用为一体的学习手册,书中介绍了应用Java Web进行程序开发的各种技术、技巧。全书分4篇,共24章,其中,第1篇为技能学习篇,主要包括Java Web开发环境...

    C#编程宝典十年典藏版代码

    C#编程宝典十年典藏版代码 非常好的源代码,值得学习和参考。

    Java编程宝典:十年典藏版6

    《Java编程宝典:十年典藏版6》是一本深入探讨Java编程技术的权威著作,旨在为读者提供全面、深入的Java学习资源。这本典藏版汇集了过去十年Java编程领域的精华,涵盖了从基础到高级,从理论到实践的各种知识点,是...

    [Visual.C++编程宝典.十年典藏版].明日科技.扫描版

    总的来说,《Visual C++编程宝典:十年典藏版》是Visual C++6.0初学者和编程爱好者的理想学习资料。通过学习本书,读者不仅能够掌握Visual C++的基础知识和编程技巧,还能通过丰富的实例和项目练习,提升自己解决...

    Java学习之道 用脑编程而不是用手

    时间并不等于经验,编程十年比编程三年的人并不一定要强。我曾经在一家软件公司做PM时,有人写代码已经八年了,而他写的代码我们测试的Bug也几乎是最多的。有人喜欢用代码行/日产量来评估一个程序员的编程能力,我...

    ASP.NET编程宝典(C#)十年典藏版

    ASP.NET编程宝典(C#)十年典藏版是一本涵盖了ASP.NET技术的全面教程,尤其适合C#开发者深入学习和参考。此书的十年典藏版代表了自ASP.NET技术诞生以来的重要发展和最佳实践的汇总,对于了解该领域的历史变迁和最新...

    vc++编程宝典十年典藏版源代码1-6章

    《VC++编程宝典十年典藏版》是深入学习C++编程的重要参考资料,它涵盖了从基础到高级的各种主题,旨在帮助读者掌握Visual C++的精髓。这个压缩包包含的源代码对应书籍的前六章,这六个章节是学习C++编程的基础,包括...

    Visual C++编程宝典十年典藏版part1

    第3篇为项目实战篇,主要包括通信新干线、使用指纹来考勤、上机课终的屏幕监控专家、让计算机听懂声音等4个小型项目;第4篇为商业系统篇,主要包括一个大型的商业项目,即企业内部通信系统。  本书适用于Visual C++...

    Visual C++编程宝典十年典藏版part2

    第3篇为项目实战篇,主要包括通信新干线、使用指纹来考勤、上机课终的屏幕监控专家、让计算机听懂声音等4个小型项目;第4篇为商业系统篇,主要包括一个大型的商业项目,即企业内部通信系统。  本书适用于Visual C++...

    十年学会编程.pdf

    ### 十年学会编程——深度解析编程学习的本质 #### 编程学习的现状与误区 在当前社会,人们对于快速掌握技能的需求日益增加,尤其是在信息技术领域。书店里充斥着诸如《7天学会Java》之类的书籍,承诺能在极短的...

    我和LabVIEW(PDF版)——一个NI工程师十年的编程经验(1).pdf

    以下是对文档【标题】:"我和LabVIEW(PDF版)——一个NI工程师十年的编程经验(1).pdf"中【部分内容】提到的知识点的详细说明: 1. LabVIEW编程的便捷性与图形化概念 LabVIEW的核心特点在于其图形化编程的概念,即...

    Visual C++编程宝典十年典藏版part3

    第3篇为项目实战篇,主要包括通信新干线、使用指纹来考勤、上机课终的屏幕监控专家、让计算机听懂声音等4个小型项目;第4篇为商业系统篇,主要包括一个大型的商业项目,即企业内部通信系统。  本书适用于Visual C++...

    我和LabVIEW-一个NI工程师十年的编程经验

    LabVIEW不仅适用于简单的程序设计,经过长时间的编程经验和学习,还能提升到设计大型软件和提高开发效率的水平。通过阅读NI提供的中高级教程和大量阅读其他人的代码,可以获得更多的编程技巧。 LabVIEW的未来发展...

    vc++编程宝典十年典藏版源代码11-12章

    总的来说,《VC++编程宝典十年典藏版》的源代码是深入学习C++编程的宝贵资源,它将理论知识与实际应用紧密结合,无论对于初学者还是专业人士,都是提升技能的理想选择。通过深入研究和实践,你将能够更好地掌握C++的...

Global site tag (gtag.js) - Google Analytics