|
|
如果你最近想自学编程,或者你是一名程序员,不妨先看看来自Google研究总监Peter Norvig的一篇学习编程的神文。
$ D6 ?. M# f2 q8 A8 W. S$ v/ n4 x7 F; {) l8 g9 {2 ~

0 s* y4 S V* S } H· 正 · 文 · 开 · 始 ·- d- F6 ]3 ?+ y( c& ~
壹 为什么每个人都这么着急?
0 t8 s& T* [9 G走进任何一家书店,你会看到很多类似《在24小时内自学Java》,以及在几天或几小时内教会你C、SQL、Ruby,算法等等这样的书籍5 d% }: {9 Z+ Q3 i. I
当我使用亚马逊高级搜索,搜索“教程、自己、小时”这些关键词时,自2000年以来,发现了512本这样类似的书籍。前10名中,有九本是编程相关的书。把“自学”替换为“学习”或者“小时”替换为“天”,都能得到类似的结果。4 E+ n/ Q; u1 z7 v& ?9 I
导致这一结果可能有两种原因,要么人们急于学习编程,要么编程在某种程度上比其他任何一种技能,都更容易学习。: I* w- `8 x7 e: k5 ], r
Felleisen et al.在他的著作《如何设计程序》一书中,说道:“糟糕的编程很容易,白痴都能在21天内学会,哪怕白痴是天生的。”1 I, S* [* i0 C; B& p9 B
让我们来看看,所谓的“24小时内学会C++”意味着什么:, M; L- ^. H8 w
1
% v4 s4 ?1 T- K学会& B7 E9 V# ~4 ` K& v' f: i. C
在这24小时里,你几乎没有时间去写任何有意义的程序,更不要说感受成功的喜悦,和从失败中汲取教训了。
/ k6 c, R9 @+ I- i I. [+ D+ s你也不可能有时间和有经验的程序员一起工作和交流,也不会体验到使用C++语言工作是什么感觉。( `+ U+ d4 k; [) o% J6 y+ j5 E
简而言之,你没有足够的时间学习。所以这样一本书只能是一种很肤浅的教程,而不是深刻的理解。正如亚历山大教皇所说:“浅层学习是很危险的。”
( j) t9 }& d, Z3 ]1 D27 |0 i8 ^( z7 {$ f9 x9 M2 w
C++4 z9 k. K9 D1 ~( |
24小时的时间,你可以学习到一些C++的语法,即便你有其他语言的基础,也无法真正学会使用C++。( R/ q5 J$ s5 H9 J0 s( X/ i B
简而言之,如果你是一名Basic程序员,你可以写出有Basic风格的C++代码,但无法发挥C++本身的优势。7 P+ p4 ~. P; U
这样学习它又有什么意义呢?Alan Perlis曾经说过:“一种不改变你编程方式的语言,不值得学习。”
# x Y4 J$ w# _. ]2 Y另外一种可能是,你只需要学习一点C++知识,然后用现有的工具制作应用接口,完成特定的编程任务。但这意味着,你并不会编程,而只是会使用一种工具而已。
1 w9 x" {" y2 E至于所谓的24小时是不可能的,这远远不够。; S3 N! Q( n4 N* W- O/ W4 h N3 E
贰 十年学会编程0 @+ F7 r9 v1 Q; D# p; Y
研究人员(Bloom (1985)、 Bryan & Harter (1899,见文后参考书目)、Hayes (1989)、Simmon & Chase (1973,见文后参考书目) 的一系列调查研究表明:
0 \ P3 Q+ Y( G U在任何一个领域,包括国际象棋、音乐、开发专业只是大约需要十年的时间。此项调查领域包括了作曲、发报、绘画、钢琴演奏、有用、网球等。
' J5 X; F! A% X& n0 w" y 科学家们从神经心理学和拓扑学的角度对这些领域进行研究,并得出一个结论。- m9 G- U7 c' ^/ \7 @) K1 d$ l
若要在某一领域内达到专家级的水平,其关键在于“审慎地重复”,也就是说,并非是机械地,一遍又一遍地练习,而是要不断地挑战自我,试图超越自身当前的水平,通过不断的尝试挑战,并在尝试的过程中和尝试之后对自身的表现进行分析和总结,吸取经验,纠正之前犯过的各种错误。把这一“审慎”的过程不断重复,才能取得成功。3 y0 k* M: T( v9 Z; Z$ f$ t
真正的捷径是不存在的。即使莫扎特在4岁时就表现出了卓越的音乐才华,可是他也花了13年的时间,才真正地写出了世界级的作品。5 A$ R& i0 _& E2 Q1 c
再举个例子,甲壳虫乐队似乎在1964年,凭借一系列热门单曲,以及爱的莎莉文秀艾德沙利文秀上的演出一炮而红。! l$ e F6 ?# O
但也许你不知道,早在1957年,他们就在利物浦和汉堡两地进行小规模演出了,而在此之前的演出更是不计其数。甲壳虫乐队的主要成名曲《Sgt. Peppers》,则是1967年才发行的。5 c4 ^+ H: y% v2 ?; Y, [6 a! I
: F0 s4 \* ]' G7 RMalcolm Gladwell公布了他对柏林音乐学院所作的一项研究的报告,该研究对比了一个班里的学习成绩为上、中下三个档次的学生,并逐一询问他们进行音乐练习的时间。
3 Z d) Z+ r# ^这三个档次中的所有人,大约都是在5岁的时候开始练习音乐的,一开始的时候大家练习音乐的时间都差不多,大约一周2到3小时。但是到了八岁左右,大家的区别就开始体现了。! h; n" \0 {) y/ u) Z' c, U$ z
后来成为班里最好的那一部分学生开始比别的学生练习得更多,大概每周6到9小时,12岁的时候每周8小时,14岁的时候每周16小时,往后则越来越多,直到20岁左右,他们每周练习音乐的时间已经超过30小时了。4 i, ~6 P0 M" P3 Q/ V
在20岁的年纪,那些精英级别的演奏家们都有累计超过10000小时的音乐练习时间。5 X4 W2 w+ r1 @8 e
相比之下,仅有部分优等生能达到8000小时的累计练习时间,而那些音乐教师级别的学生,他们的累计练习时间只有4000小时左右。
0 o: d- @" N$ x2 Z; O所以,如果你想在某一领域有所建树,至少要10000个小时的时间,而不是10年。Henri Cartier-Bresson说过:“作为摄影师,你所拍摄的头10000张照片都是垃圾。”也是一样道理。9 I; G8 H$ d7 a7 n! h
叁 如果你想成为一名程序员7 m3 [9 K. s9 U3 U: m5 \# B
以下是我成功的一些秘诀:
( t, `# \; U% R: T' k4 }; q3 W! f( r0 P# H+ V1 H# f
- 沉迷
3 Y- R+ S( ~, P0 Z$ |& E x 沉迷于编程,确保你有足够的热情,以便于你能为其投入十年/10000个小时。
/ O- a; K/ K8 s, g9 ]- q$ C( Z+ j5 u$ r/ b- U
- 计划
" `3 C6 |3 f" v0 m; Z/ a 边学习、边实践。说得专业一些,一个人在某个专业领域达到了最高水平,并不是因为个人经验而自动获得的,而是为了进步,努力之后产生的结果。5 u& l2 W V' Z- u! g( F% u* P
; f2 |% ]& r& o G5 p- 交流
' s/ B( c( Q s7 A 与其他程序员交流,多阅读其他人写的程序。这些远比你看书或者上培训班重要
4 M# ^. l' }8 t% {2 h2 V. A _! X' q" f% o" m) J
- 学习4 s, j1 N: r, I4 w8 r9 E. x2 _
如果有条件,尽量去读一个计算机专业吧,当然能读研更好。如果你能做到这一点,你将更有机会得到要求“计算机相关专业”的岗位,对这个行业,你将有一个更深的理解。; ^2 j# z8 r5 c$ V
不过,如果你不是上学的料,你可以考自学,当然这需要足够的毅力,或者通过工作来积累经验。1 `* k( H) c1 x @ s# y8 S
$ z; R8 u! t* f9 u9 S9 M
无论你采用哪一种途径,光靠书本是远远不够的。9 X' n( t; n1 c. p# b
; I( y; M! |4 ~" Z6 O n
4 B$ y5 o3 J, g8 _1 A% A9 |- 实践3 N5 j" t/ i; f+ y$ f4 o9 g
与其他同行一起做项目,成为当中最好的程序员,或者最糟糕的程序员。当你是团队中最好的程序员时,你的领导能力会得到锻炼。当你是最差的那一个时,你会了解到你的领导不喜欢哪些事。
- S0 V/ l% i% p5 I因为领导总是把那些他们自己不喜欢做的杂事,丢给那些他们认为能力很差的人去做。
+ U$ @! Q7 n) p9 c5 j+ o
' o0 c; ]+ {5 o) w. r ~/ d4 | _' T" H
- 理解5 I. @. Q5 a' T+ Y0 ?
跟随一些优秀的程序员做项目,理解他们写的代码,如果它们的编写者不在,看看理解和修正他的代码,会付出什么样的代价。并同时思考,如何规划你的代码,让他们更容易被他人理解和维护。* P* \2 l1 F7 [) f6 a Z1 p9 y2 O( b
要学会更多的编程语言。包括一种支持类抽奖的语言(如Java或C++),一种支持函数抽奖的语言(如Lisp、ML或Haskell),一种支持于法雷抽象的语言(Lisp),一种支持协同程序的语言(例如Icon或者Scheme),一种支持平行并发编程的语言(例如Sial)。
) ?. r/ t8 p0 j+ _, V' c) K: `
$ ]7 Z1 v2 Q. r: ~3 Q- 牢记
/ n: ^# j7 c5 P7 f! s7 y9 i0 a2 U 牢记“计算机科学”中包含着“计算机”这个词。了解计算机需要花多长的时间执行一条指令,花多长时间从内存中获取一个字(word)(包括缓存命中和不命中两种情况)。
, H; h5 v2 n9 a, K+ C如果连续从磁盘中获取数据,时间消耗如何?以及需要花多少时间才能再磁盘上定位一个新的位置?
+ n+ ?4 T& B4 h/ Q7 @
2 p0 U7 r3 d# l, V- 规范3 A |3 ]: T L! Q1 T
尽量参与语言的标准化过程。往大了说,你可以试着加入ANSI C++委员会这样的专业组织,往小了讲,你也可以从自己的代码规范入手,限定代码缩进是需要2个空格宽还是4个空格宽。0 T! _3 a/ C: ~
无论采用哪种方式,你都需要了解其他人对于语言的喜好,以及他们的喜好的程度,甚至你要知道他们为什么产生这样的喜好的原因。0 L8 M. h" P, n0 x) G
; T( m% Q% ^: r( c# @) W+ N5 [1 l- 意识
* l, X( P6 ]8 G8 Z3 `3 k. ^+ `; z0 y 要掌握上面所说的所有内容,光靠看书学习应该是很难做到的。当我的第一个孩子出生的时候,我几乎阅读了市面上所有的《如何…》指南书籍,但是我读完了以后还是觉得自己是个菜鸟。# O; y# D7 u7 e$ R. ^# Y" E
30个月以后,我的第二个孩子快出生时,我难道还要做一个书虫么?不!相反,我此时更依赖我的个人经验,这些经验相比于那些上千页的书籍,则更加有效和让我放心。
/ C, T* Q: w+ s/ ~肆 附录:如何选择语言
' s- x/ U& T. F5 z
: \# C# Q p; j( a) Q# w曾经很多人问我,应该选择什么编程语言作为入门?这个问题很难给出一个确切的回答,但你可以从以下几个方面考虑。" q& D, \. [3 ~. H2 T
问问你的朋友
3 \5 \- Y* j* ]5 M当我被问及“我应该使用哪一种操作系统,Windows、Unix、Mac?”时,我的回答通常是:“你朋友在用什么,你就用什么。”+ t5 F8 S, l: C4 ?2 Z3 _
这么做的好处是,有了你朋友的帮助,你就能有效地回避操作系统固有的一些差异,对于选择编程语言来说,也是同样道理。0 d6 ^9 U* c1 S
同时,你还要有点儿战略眼光:如果选择了一种编程语言,并成为其编程社区的一员,那么你选择的语言和社区是正在不断壮大?还是奄奄一息?如果你有编程方面的问题,能不能从相关的书籍,网站以及在线论坛中得到解答?你是不是跟论坛里的人合得来?这些都是要考虑的。
! g0 s) D/ b: ^1 A0 d6 t. o简单实用/ r+ {) d. C( o ~) p4 I& _3 Q
诸如C++以及Java这样的编程语言都是非常专业的开发语言,适用于有经验的大型团队进行开发,需要时常考虑代码的运行效率。所以,这类的编程语言就适合于那样(复杂)的编程环境。如果你是一个初学者,那么就不要搞那么复杂。你所需要的是一种简单易学的编程语言,你靠你自己就可以搞定的语言。
! H0 x* i8 g0 F# s8 Z" B交互
3 }' `/ O; V5 r o$ ?7 v; M7 q, R l给你两种选择去学钢琴:第一种,常规做法,也是互动的做法,也就是你每敲一下琴键就能听到琴音;第二种,批量模式,等你把所有该按的琴键都按了一遍,然后再一次性放给你听。你选择哪一个呢?显然,交互式的方式对于钢琴学习来说更容易,对于编程学习也是如此。那么就坚持使用交互式模式学习编程吧。/ M, K% h. L. |; {: Y% S- `8 @# k+ Y
) o4 x% @% H0 C2 V$ J
来源:http://www.yidianzixun.com/article/0MS1fL0b
S. o8 G) t. I免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|