我記得剛接觸計(jì)算機(jī)的時(shí)候,我就受到了兩個(gè)非常巨大的錯(cuò)誤觀念的影響,這個(gè)觀念最初是來(lái)自于老師的傳授還是學(xué)長(zhǎng)的教誨已經(jīng)記不清了,但是直到我工作幾年以后,才慢慢有了實(shí)際的體會(huì):
學(xué)習(xí)和使用什么編程語(yǔ)言不重要,重要的是算法和設(shè)計(jì);
程序員學(xué)習(xí)的精髓是面向?qū)ο蟮脑O(shè)計(jì)模式,掌握以后,一通百通。
簡(jiǎn)直就是是胡扯啊。也許在某個(gè)極其狹隘的上下文中還能這樣說(shuō),但是泛泛而談,這樣的態(tài)度無(wú)疑是誤人子弟的。
就說(shuō)第一條,編程語(yǔ)言不但重要,而且太重要了。換句話(huà)說(shuō),學(xué)習(xí)一門(mén)新的編程語(yǔ)言,可能學(xué)習(xí)的是背后的范型和思考問(wèn)題的方式。如果這個(gè)部分能帶來(lái)新的東西,那就是值得花時(shí)間投入的。
可能很多人和我的背景一樣,熟悉Java和JavaScript,一門(mén)是經(jīng)典的靜態(tài)語(yǔ)言,一門(mén)是經(jīng)典的動(dòng)態(tài)語(yǔ)言。有人說(shuō)相較而言,搞C++背景的人算法和數(shù)據(jù)結(jié)構(gòu)基礎(chǔ)更加扎實(shí);而起初搞Java背景的人可能設(shè)計(jì)方面懂的多一點(diǎn),但是水貨更多;而說(shuō)起JavaScript,就似乎更“低廉”了,雖說(shuō)學(xué)好太難,但入門(mén)門(mén)檻超低。于是針對(duì)像我這樣背景的工程師,我打算用類(lèi)比Java和JavaScript的方式寫(xiě)一些新的編程語(yǔ)言的學(xué)習(xí)筆記,因?yàn)樵谖铱磥?lái),用“類(lèi)比”的方式是學(xué)習(xí)印象深刻,而且容易更容易理解的有效方式。以前也用類(lèi)似的方式寫(xiě)過(guò)一些新技術(shù)的學(xué)習(xí)筆記,比如《GWT初體驗(yàn)》。但是通常要學(xué)習(xí)一門(mén)新的編程語(yǔ)言,尤其是從未熟悉的一個(gè)新的編程范型,學(xué)習(xí)曲線(xiàn)要比這個(gè)高得多。在我的腦海里有這樣一個(gè)清單,記載了最想接觸和熟悉的編程語(yǔ)言,這個(gè)清單最首要就包括:
Groovy。學(xué)習(xí)Groovy就是奔著“動(dòng)態(tài)語(yǔ)言”去的,而動(dòng)態(tài)語(yǔ)言,就是奔著“元編程”去的。“動(dòng)態(tài)”,是指在程序運(yùn)行過(guò)程中可以改變數(shù)據(jù)類(lèi)型的結(jié)構(gòu)。也就是說(shuō),是圍繞著“元編程”產(chǎn)生的特性。元編程,指的是在運(yùn)行時(shí)改變“類(lèi)”的定義,例如訪問(wèn)、增加或修改等等。一言以蔽之,就是“用程序來(lái)寫(xiě)程序”。Groovy是和Java最親近的動(dòng)態(tài)語(yǔ)言。07年底接觸過(guò)一段時(shí)間Groovy程序,還混過(guò)當(dāng)時(shí)Groovy中國(guó)社區(qū)的斑竹,只可惜本人如此喜愛(ài)掛念的東西,現(xiàn)在依然不算多活躍,在最新的TIOBE排行上面,列在36位,有趣的是,35位的是Scala,真可謂難兄難弟。這里有個(gè)小段子,Groovy的作者James Strachan說(shuō),如果當(dāng)年他看到了Scala,就不會(huì)有Groovy什么事兒了。即便是這種自掘墳?zāi)故降淖放?,如今看?lái)Scala的下場(chǎng)也沒(méi)見(jiàn)得好到哪去。JavaScript也一樣是動(dòng)態(tài)語(yǔ)言,為什么還要接觸Groovy?其中一個(gè)重要原因是其中的元編程特性太豐富。
Haskell。純粹的函數(shù)式語(yǔ)言。可以這樣理解“純粹”一說(shuō):有一些語(yǔ)言“可以”進(jìn)行函數(shù)式編程,但是有的則是“不得不”進(jìn)行函數(shù)式編程。編程語(yǔ)言發(fā)展的兩大趨勢(shì)就是動(dòng)態(tài)語(yǔ)言和函數(shù)式語(yǔ)言。因此有了Groovy代表動(dòng)態(tài)語(yǔ)言,接著我一直想學(xué)習(xí)一門(mén)函數(shù)式語(yǔ)言。函數(shù)式編程就像數(shù)學(xué)中的函數(shù)一樣,唯一給定了輸入?yún)?shù),就可以唯一確定輸出結(jié)果,沒(méi)有上下文的影響,沒(méi)有執(zhí)行次數(shù)的影響,或者說(shuō)是天然冪等的。網(wǎng)上太多文章批Haskell太過(guò)學(xué)院派,連教科書(shū)里面要教授函數(shù)式編程都用Scheme(因?yàn)樗讓W(xué),還沒(méi)有那么復(fù)雜的類(lèi)型系統(tǒng)),但是開(kāi)闊視野無(wú)疑是非常好的(“代碼原來(lái)可以這樣寫(xiě)!”),尤其喜愛(ài)其中的模式匹配的特性。
當(dāng)然還有其它的,有代表性的語(yǔ)言想深入研究,比如邏輯式的Prolog,還有可以寫(xiě)詩(shī)的Perl……但是也害怕吃得太多就會(huì)撐著。
Haskell之于函數(shù),就像Perl之于字符串,就像Prolog之于謎題,就像Groovy之于DSL。
我會(huì)記錄和討論一些語(yǔ)言特性,但是不會(huì)去討論大多數(shù)語(yǔ)法糖這樣可能重要但是瑣碎的部分。如果只是純粹的學(xué)習(xí)筆記那多無(wú)聊啊,還不如把它寫(xiě)成吐槽帖。我爭(zhēng)取從Java和JavaScript到Haskell和Groovy,對(duì)這四門(mén)語(yǔ)言,一個(gè)特性一個(gè)特性地橫向比較,比如站在類(lèi)型系統(tǒng)的角度,弱類(lèi)型、強(qiáng)類(lèi)型,靜態(tài)的、動(dòng)態(tài)的,類(lèi)型之間的關(guān)系、類(lèi)型創(chuàng)建等等;再比如元編程方面,Java的反射和代理系統(tǒng),JavaScript的prototype,Groovy強(qiáng)大的元編程體系,還有Haskell的編譯期元編程實(shí)現(xiàn)等等。
更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄